欢迎来到天天文库
浏览记录
ID:19416093
大小:29.50 KB
页数:7页
时间:2018-10-02
《ajax入门教程-http协议基础07274》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、AJAX入门教程-HTTP协议基础07274dplicn=AJAX入门教程-HTTP协议基础要很好地领会Ajax技术的关键是了解超文本传输协议(HTTP),该协议用来传输网页、图像以及因特网上在浏览器与服务器间传输的其他类型文件。只要你在浏览器上输入一个URL,最前面的http://就表示使用HTTP来访问指定位置的信息。(大部分浏览器还支持其他一些不同的协议,其中FTP就是一个典型例子。) 注意:本文中只涉及HTTP协议,这是Ajax开发人员关心的方面,它可作为HTTP的参考手册或指南。 HTTP由两部分组成:请求和响应。当
2、你在Web浏览器中输入一个URL时,浏览器将根据你的要求创建并发送请求,该请求包含所输入的URL以及一些与浏览器本身相关的信息。当服务器收到这个请求时将返回一个响应,该响应包括与该请求相关的信息以及位于指定URL(如果有的话)的数据。直到浏览器解析该响应并显示出网页(或其他资源)为止。 HTTP请求 HTTP请求的格式如下所示:<request-line><headers><blankline>[<request-body>] 在HTTP请求中,第一行必须是一个请求行(requestline),用来说明请求类型、要访问的资源
3、以及使用的HTTP版本。紧接着是一个首部(header)小节,用来说明服务器要使用的附加信息。在首部之后是一个空行,再此之后可以添加任意的其他数据[称之为主体(body)]。 在HTTP中,定义了大量的请求类型,不过Ajax开发人员关心的只有GET请求和POST请求。只要在Web浏览器上输入一个URL,浏览器就将基于该URL向服务器发送一个GET请求,以告诉服务器获取并返回什么资源。对于www.wrox.com的GET请求如下所示:GET/HTTP/1.1Host:www.wrox.comUser-Agent:Mozilla/5
4、.0(Windows;U;WindowsNT5.1;en-US;rv:1.7.6)Gecko/20050225Firefox/1.0.1Connection:Keep-Alive 请求行的第一部分说明了该请求是GET请求。该行的第二部分是一个斜杠(/),用来说明请求的是该域名的根目录。该行的最后一部分说明使用的是HTTP1.1版本(另一个可选项是1.0)。那么请求发到哪里去呢?这就是第二行的内容。 第2行是请求的第一个首部,HOST。首部HOST将指出请求的目的地。结合HOST和上一行中的斜杠(/),可以通知服务器请求的是ww
5、w.wrox.com/(HTTP1.1才需要使用首部HOST,而原来的1.0版本则不需要使用)。第三行中包含的是首部User-Agent,服务器端和客户端脚本都能够访问它,它是浏览器类型检测逻辑的重要基础。该信息由你使用的浏览器来定义(在本例中是Firefox1.0.1),并且在每个请求中将自动发送。最后一行是首部Connection,通常将浏览器操作设置为Keep-Alive(当然也可以设置为其他值,但这已经超出了本书讨论的范围)。注意,在最后一个首部之后有一个空行。即使不存在请求主体,这个空行也是必需的。 如果要获取一个诸如
6、http://www.wrox.com/books的www.wrox.com域内的页面,那么该请求可能类似于:GET/books/HTTP/1.1Host:www.wrox.comUser-Agent:Mozilla/5.0(Windows;U;WindowsNT5.1;en-US;rv:1.7.6)Gecko/20050225Firefox/1.0.1Connection:Keep-Alive 注意只有第一行的内容发生了变化,它只包含URL中www.wrox.com后面的部分。 要发送GET请求的参数,则必须将这些额外的信息
7、附在URL本身的后面。其格式类似于:URL?name1=value1&name2=value2&..&nameN=valueN 该信息称之为查询字符串(querystring),它将会复制在HTTP请求的请求行中,如下所示:GET/books/?name=Professional%20AjaxHTTP/1.1Host:www.wrox.comUser-Agent:Mozilla/5.0(Windows;U;WindowsNT5.1;en-US;rv:1.7.6)Gecko/20050225Firefox/1.0.1Connect
8、ion:Keep-Alive 注意,为了将文本“ProfessionalAjax”作为URL的参数,需要编码处理其内容,将空格替换成%20,这称为URL编码(URLencoding),常用于HTTP的许多地方(JavaScript提供了内建的函数
此文档下载收益归作者所有