目标:了解请求和响应是怎样运作的。
3.1 HTTP报文
3.2 请求报文及响应报文的结构
请求和响应报文的首部内容一般由一下数据组成
请求行
包含用于请求的方法,请求URI和HTTP版本
状态行
包含表明响应结果的状态码,原因短语和HTTP版本
首部字段
包含表示请求和响应的各种条件和属性的各类首部。
一般有4种首部,分别是通用、请求、响应、实体首部。
其他
可能包含HTTP的RFC里未定义的首部(Cookie等)。
3.3编码提升传输速率
报文
HTTP通信的基本单位,由8位组字节流组成,通过HTTP通信传输。
实体
作为请求或响应的有效载荷数据被传输,其内容由实体首部和实体主体组成。
一般情况HTTP报文主体
= 实体主体
,当传输过程中进行了编码操作,两者会出现差异。
压缩传输的内容编码
4种常见的内容编码类型
- gzip
- compress
- deflate
- identity(不进行编码)
分割发送的分块传输编码
3.4发送多种数据的多部分对象集合
对比发送邮件时采用的MIMIE(多用途因特网邮件扩展)机制
它允许邮件处理文本、图片、视频等多个不同类型的数据。
HTTP协议也采用了多部分对象集合,发送的一份报文主体内可含有多类型实体。通常是在图片或文本文件等上传时使用。
多部分对象集合包括:
- multipart/form-data
multipart/byteranges
使用时需在首部字段加入Content-Type。
使用boundary字符串来划分
3.5获取部分内容的范围请求
需要用到首部字段Range
来指定资源的byte范围。
指定形式有三种:
Range: bytes=5001-10000
表示5000到10000字节Range: bytes=5001-
表示5001字节以后的所有字节Range: bytes=-3000, 5000-7000
表示从一开始到3000字节和5000-7000字节的多重范围。
对于范围请求,响应会返回状态码为206 Partial Content的响应报文。
如果服务器端无法响应范围请求,则会返回状态码200 OK和完整的实体内容。
3.6内容协商返回最合适的内容
三种类型
- 服务器驱动协商
- 客户端驱动协商
- 透明协商