本章节针对HTTP协议结构进行讲解,主要使用HTTP/1.1版本。
HTTP协议和TCP/IP协议族内的其他众多的协议相同,用于客户端和服务器之间的通信。
请求访问文本或图像的一端称为客户端,提供资源响应的一端称为服务器。
在两台计算机使用HTTP协议通信时,在一条通信线路上必定一端是客户端,另一端是服务器端。
HTTP协议规定,请求从客户端发出,最后服务器端响应该请求并返回。
肯定是从客户端开始建立通信的,服务器端在没有接收到请求之前不会发送响应。
我们来看一组例子:
客户端
发送请求:
GET/index.htm HTTP/1.1
Host:hackr.jp
起始行开头的GET表示请求访问服务器的类型,称为方法。随后的字符串/index.htm指明了请求访问的资源对象,也叫做请求URI。最后的HTTP/1.1,即HTTP的版本号,用来提示客户端使用的HTTP协议功能。
综合来看,这段请求内容的意思是:请求访问某台HTTP服务器上的/index.htm页面资源。
请求报文是由请求方法、请求URI、协议版本、可选的请求首部字段和内容实体构成。
POST /form/entry HTTP/1.1
方法 URI 协议版本
Host:hack.jp
Connection:keep-alive 请求首部字段
Content-Type:application/x-www-form-urlencoded
Content-Length:16
name=ueno&age=37 内容实体
接下来我们看接收到请求的服务器,会将请求内容的处理结果以响应的形式返回。
服务器
发送响应:
HTTP/1.1 200 OK
Date:True,10 Jul 2012 06:50:15 GMT 响应首部字段
Content-Length:362
Content-Type:text/html
在开头起始行的HTTP/1.1表示服务器对应的HTTP版本。
紧接着的***200 OK***表示请求的处理结果状态码和原因短语。
下一行显示了创建响应的日期时间,是首部字段的一个属性。
响应报文基本上由协议版本、状态码、用于解释状态码的原因短语、可选的响应首部字段以及实体主题构成。
HTTP是一种不保存状态,即无状态协议。
HTTP协议自身不对请求和响应之间的通信状态进行保存。也就是说在HTTP这个级别,协议对于发送过的请求和响应不做持久化处理。
协议本身不保留之前一切的请求或响应报文的信息,这样做是为了更快捷地处理大量数据,确保协议地可伸缩性,而特意把HTTP协议设计成如此简单地。
但是随着网络的发展,因无状态而导致业务处理变得棘手的情况增多了。为了实现期望的保持状态功能,为此引入了Cookie技术。
有关Cookie的技术在后面的文章中会提到QWQ
前面说到,网络中我们能看到各式各样的图片和文章,这离不开URI的功劳。
当客户端请求访问资源而发送请求时,URI需要将作为请求报文中的请求URI包含在内。
举两个栗子:
----------------------------------------
URI为完整的请求URI
GET http://hackr.jp/index/htm HTTP/1.1
----------------------------------------
在首部字段Host中写明网络域名或IP地址
GET /index/htm HTTP/1.1
Host:hackr.jp
----------------------------------------
除此之外,如果不是访问特定资源,而是对服务器本身发起请求,可以用一个*(星号)来代替请求URI。
再举个栗子:
OPTIONS * HTTP/1.1
以上就是本章的全部内容,下一篇将会是一个小重点qwq
我是奶嘴!欢迎大家探讨交流QWQ鄙人在此感激不尽!