《图解HTTP》笔记--HTTP协议

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
    
    
    ......
    

    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连接建立和断开,增加通信量的开销。

  1. keep-alive
    为了解决上述TCP连接问题,想出了长连接(HTTP Persistent Connections,也称为HTTP keep-alive 或HTTP connection reuse)的方法。持久连接的特点是,只要任意一端没有明确提出断开连接,则保持TCP连接状态。
    建立一次TCP连接后请求多次请求和响应交互。

    建立一次TCP连接后请求多次请求和响应交互

  2. 管线化
    长连接使得多请求以管线化方式发送称为可能。
    管线化不等待响应,直接发送下一个请求。

    管线化:不等待响应,直接发送下一个请求

你可能感兴趣的:(《图解HTTP》笔记--HTTP协议)