HTTP协议简介

HTTP协议(Hyper Text Transfer Protocol),字面意思为超文本传输协议。是浏览器与服务器之间的传输协议,属于应用层面向对象的协议。

用户通过浏览器向服务器发送HTTP请求信息(Request),服务器收到请求后,向浏览器发送响应信息(Response)

我们用例子分析一下请求信息与响应信息具体是怎么样的。

HTTP请求信息

用浏览器打开网页之后,按F12,会出现一个开发者工具界面,在里面可以看到网页的结构、通信信息等。

我们以163网易为例,在进入网易官网后,按F12,在出现的界面中选择network,然后在左侧选择第一个文件,之后右侧就会显示相关信息,点击view source可以看到具体的信息。






html5 请求文件夹的json文件 http请求html_python


HTTP_1.png


我们截取部分信息来分析一下。

先来看请求信息:


GET / HTTP/1.1
Host: www.163.com
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/57.0.2987.98 Safari/537.36 LBBROWSER
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
Referer: http://www.163.com/
Accept-Encoding: gzip, deflate, sdch, br
Accept-Language: zh-CN,zh;q=0.8



第一部分,是请求行。说明请求类型、访问资源以及HTTP版本。在这里是第一行。
GET表示请求类型是GET请求,/表示URL路径,/是首页,HTTP/1.1表示采用的HTTP协议是1.1版本.

第二部分,是请求头部。说明服务器要使用的附加信息。在这里第一行往后都属于这一部分。
其中Host表示请求的域名。

第三部分,空行。请求头部后面的空行是必须的。

第四部分,请求数据。这里没有请求数据。

HTTP响应信息

我们再来看一下响应信息部分:


HTTP/1.1 200 OK
Expires: Thu, 20 Sep 2018 07:39:34 GMT
Date: Thu, 20 Sep 2018 07:38:14 GMT
Server: nginx
Content-Type: text/html; charset=GBK
Transfer-Encoding: chunked
Vary: Accept-Encoding,User-Agent,Accept
Cache-Control: max-age=80
Content-Encoding: gzip
X-Via: 1.1 PSgdmmsxsw84:1 (Cdn Cache Server V2.0), 1.1 PSgdzsydzd33:0 (Cdn Cache Server V2.0)
Connection: keep-alive



第一部分,状态行。说明HTTP版本、信息状态码和状态信息。这里是第一行。
状态码200表示请求成功。请求状态的情况:
2xx: 成功--表示请求已被成功接收、理解、接受
3xx: 重新定向--要求要完成请求必须进行更进一步的操作
4xx: 客户端错误--请求有语法错误或请求无法实现
5xx: 服务器端错误--服务器未能实现合法请求

第二部分,信息报头。说明客户端要使用的一些附加信息。第一行后面的都是。
其中Content-Type表示响应的内容,text/html表示HTML网页。

第三部分,空行。消息报头后面的空行是必须的。

第四部分,响应正文。即HTML源码。
我们在开发者工具中点击Response,就能看到:



html5 请求文件夹的json文件 http请求html_后端_02


HTTP_2.png


HTTP工作原理

看了HTTP的请求信息和响应信息,我们来总结一下HTTP的工作原理。

第一步,建立连接
浏览器与Web服务器的端口建立一个TCP连接。

第二步,发送HTTP请求
浏览器向服务器发送HTTP请求,包括请求方法、路径、域名以及其他相关Header。

第三步,接收HTTP请求并返回响应信息
Web服务器解析请求,并返回响应信息,包括响应状态、响应类型、其他相关Header以及响应正文。

第四步,释放连接或继续请求
若connection为close,则Web服务器主动断开连接;若connection为keepalive,则Web服务器继续等待请求。

第五步,解析响应信息
浏览器解析响应信息,包括响应头和响应正文。最终解析HTML文本并显示出来。

以上就是本节的全部内容,希望对你的学习有所帮助。