本文正在参与 “网络协议必知必会”征文活动
关于HTTP协议
- 应用
HTTP协议
时,必定是一端担任客户端角色,一端担任服务器端角色 HTTP协议
通过请求和响应的交换达成通信。请求从客服端发出,最后服务器端响应该请求并返回HTTP协议
是不保存状态的,即无状态协议,协议对发送或响应的请求都不作持久化处理
告知服务器意图的HTTP方法
GET
:获取资源
GET
方法用来请求已经被URI标识的资源
POST
:传输实体主体
POST
方法用来传输实体的主体。POST
方法和GET
方法功能相似,但是POST
的主要目的并不是获取响应的主体内容
PUT
:传输文件
PUT
方法用来传输文件。在请求报文的主体中包含文件内容,然后保存到请求URI
指定的位置
DELETE
:删除文件
DELETE
方法用来删除文件。与PUT
相反的方法,DELETE
方法按请求URI
删除指定的资源
HEAD
:获得报文首部
HEAD
方法和GET
方法一样,但是不返回报文主体部分,用于确认URI
的有效性及资源更新的日期时间等
OPTIONS
:询问支持的方法
OPTIONS
方法用来查询针对请求URI指定的资源支持的方法
TRACE
:追踪路径
发送请求时,在Max-Forward首部字段中填入数值,每经过一个服务器端就将该数字减1,当数值刚好减到0时,就停止继续传输,最后接收到请求的服务器端则返回状态码200 OK的响应
客户端通过TRACE
方法可以查询发出去的请求是怎么被加工修改的,这是因为,请求想要连接到源目标服务器可能会通过代理中转,TRACE
方法就是用来确认连接过程中发生的一些列操作
CONNECT
:要求用隧道协议连接代理
CONNECT
方法要求在代理服务器通信时建立隧道,实现用隧道协议进行TCP
通信,主要使用SSL
(Secure Sockets Layer,安全套接层)和TLS
(Transport Layer Security,传输层安全)协议把通信内容加密后经网络隧道传输
持久连接节省通信量
- HTTP协议的初始版本中,每进行一次HTTP通信就要断开一次TCP连接
比如,使用浏览器浏览一个包含多张图片的HTML页面时,在发送请求访问HTML页面资源的同时,也会请求该HTML页面里包含的其他资源。因此,每次的请求都会造成无谓的TCP连接建立和断开,增加通信量的开销
- 持久连接
只要任意一端没有明确提出断开连接,则保持TCP连接状态
持久连接的好处在于减少了TCP连接的重复建立和断开所造成的额外开销,减轻了服务器端的负载。另外,减少开销的那部分时间,使HTTP请求和响应能够更早地结束,这样Web页面的显示速度也就相应提高了
- 管线化
持久连接使得多数请求以管线化(pipelining)方式发送成为可能
从前发送请求后需等待并收到响应,才能发送下一个请求。管线化技术出现后,不用等待响应亦可直接发送下一个请求。这样就能够做到同时并行发送多个请求,而不需要一个接一个地等待响应了。
使用Cookie的状态管理
- 引入
Cookie
技术的原因
由于HTTP
是无状态协议,假设要求登录认证的Web页面本身无法进行状态的管理(不记录登录状态),那么每次跳转新页面都需要再次登录
- 使用
Cookie
技术管理状态
Cookie
技术通过在请求和响应报文中写入Cookie
信息来控制客户端的状态。
Cookie
会根据从服务器端发送的响应报文内的一个叫做Set-Cookie
的首部字段信息,通知客户端保存Cookie
。当下次客户端再往该服务器发送请求时,客户端会自动在请求报文中加入Cookie
值后发送出去。服务器端发现客户端发送过来的Cookie
后,会去检查究竟是从哪一个客户端发来的连接请求,然后对比服务器上的记录,最后得到之前的状态信息。
+ 第一次,没有`Cookie`信息状态下的请求

+ 第二次及以后,存在`Cookie`信息状态下的请求

本文转载自: 掘金