HTTP协议和TCP/IP协议族内的其他众多协议相同,用于客户端和服务器之前的通信。
在两台计算机之间使用HTTP协议通信时,在一条通信线路上必定有一端是客户端,另一端则是服务器端。
HTTP示例
-
请求示例:
GET /index.htm HTTP/1.1 Host: hacks.jp
GET
:表示请求访问服务器的类型,称为方法
/index.htm
:指明了请求访问的资源对象,也叫做URI
HTTP/1.1
:HTTP版本号,用来提示客户端使用HTTP协议功能 -
响应示例:
HTTP/1.1 200 OK Date:Tue,10 Jul 2018 06:50:15 GMT Content-Length:362 Content-Type:text/html <html> ......
HTTP/1.1
:服务器对应的HTTP版本
200 OK
:请求处理结果的状态码和原因短语
Date、Content
:首部字段内的属性
空行分割之后的内容称为资源实体的主体
HTTP/1.1支持的方法
方法 | 说明 |
---|---|
GET | 获取资源 |
POST | 传输实体主体 |
PUT | 传输文件 |
HEAD | 获取报文首部 |
DELETE | 删除文件 |
OPTIONS | 询问支持的方法 |
TRACE | 追踪路劲 |
CONNECT | 要求用隧道协议连接代理 |
HTTP是不保存状态的协议
HTTP协议自身不对请求和响应之间的通信状态进行保存。协议对于发送过的请求或响应都不做持久化处理。
- 无状态协议:
优点:可以减少服务器CPU及内存资源的消耗。
缺点:不对之前发生过得请求和响应进行状态管理。也就是说,无法根据之前的状态进行本次的请求处理
随着Web的不断发展,因无状态而导致业务处理变得棘手。
保留无状态协议这个特征的同时又要解决类似的矛盾问题,于是引入的Cookie技术。有了Cookie再用HTTP协议通信,就可以管理状态了。
- Cookie工作原理
Cookie技术通过在请求和响应报文中写入Cookie信息来控制客户端的状态。
Cookie会根据中服务端发送的响应报文内的一个叫做Set-Cookie的首部字段信息,通知客户端保存Cookie。当下次客户端再往该服务器发送请求时,客户端会自动在请求报文中加入Cookie值后发送出去。
服务器端发现客户端发送过来的Cookie后,会去检查是从哪个客户端发送来的连接请求,然后对比服务器上的记录,最后得到之前的状态信息。
HTTP长连接
HTTP协议初始版本中,每进行一次HTTP通信就要断开一次TCP连接。
随着HTTP普及,现在浏览一个HTML页面时,在发送请求HTML页面资源的同时,也会请求该HTML页面包含的其他资源。因此每次的请求都会造成无谓的TCP连接建立和断开,增加通信量的开销。
-
keep-alive
为了解决上述TCP连接问题,想出了长连接(HTTP Persistent Connections,也称为HTTP keep-alive 或HTTP connection reuse)的方法。持久连接的特点是,只要任意一端没有明确提出断开连接,则保持TCP连接状态。
建立一次TCP连接后请求多次请求和响应交互。
-
管线化
长连接使得多请求以管线化方式发送称为可能。
管线化不等待响应,直接发送下一个请求。