http报文包括起始行、首部和主体。
HTTP请求/响应起始行
请求组成: 方法 + 请求URL + HTTP版本
响应组成: HTTP版本 + 数字状态码 + 描述状态的原因短语
HTTP首部
首部内容为客户端和服务器分别处理请求和响应提供所需要的信息。首部和方法配合工作,共同决定了客户端和服务器能做什么。
通用首部
客户端和服务器都可以使用的首部
首部 |
描述 |
值 |
Connection |
是否需要持久连接 |
Keep-alive |
Cache- Control |
缓存控制 |
private:内容只缓存到私有缓存中(仅客户端); public:所有内容都将被缓存(客户端和代理服务器都可缓存); max-age= 25 :缓存将在25s后失效,需要重新访问服务器; no-cache:必须先与服务器确认返回的响应是否被更改,然后才能使用该响应来满足后续对同一个网址的请求,验证ETag; no-store:响应不被缓存; must-revalidation/proxy-revalidation:如果缓存的内容失效,请求必须发送到服务器/代理以进行重新验证 |
Data |
首部字段data表明创建HTTP报文和日期。 |
|
Via |
追踪客户端与服务器之间的请求响应和响应报文的传输途径。还可以避免请求回环的发生。 |
|
Warning |
告知用户一些与缓存相关问题的警告 |
|
Transfer- Encoding: |
规定了传输报文主体时采用的编码方式 |
请求首部中常用字段详解
首部 |
描述 |
值 |
Accept |
客户端支持的媒体类型 |
"text/html,iamge/*" |
Accept-Encoding |
客户端支持的编码方式 |
"gzip, compress" |
Accept-Charset |
客户端支持的/字符集 |
"iso8859-5" |
Accept-Language |
客户端支持的语言 |
"en, fr" |
Except |
||
If - Modified - Since |
浏览器缓存页面的最后修改时间,服务器会将该时间与服务器时间对比,如果超出该时间则返回新内容,否则返回304 |
Time |
Range |
如果服务器支持请求的范围,则返回资源的指定范围 |
Range |
Content - Length |
请求消息正文的长度 |
|
Referer |
包含一个URL,用户从该URL代表的页面出发访问当前请求的页面 |
url |
User - Agent |
浏览器类型 |
|
Trailer |
首部字段Trailer会事先说明在报文主体后记录了哪些首部字段,可以应用在HTTP1.1版本分块传输编码时使用。 |
响应首部中常用字段详解
首部 |
描述 |
值 |
Accecpt-Ranges "none" |
服务器可接受的范围和类型 |
|
Age |
从原始服务器到代理缓存形成的估算时间(以秒记, 非负) |
|
ETag |
设置文件是否被修改 |
|
Last-Modified |
请求资源的最后修改时间 |
|
Serve |
服务器应用程序的名称 |
|
Set-cookie |
设置cookie |
|
Proxy-Authenticate |
代理对客户端的质询列表 |
Basic |
实体首部中常用字段详解
首部 |
描述 |
值 |
Content-encoding |
主体编码方式 |
|
Content-Language |
主体语言 |
|
Content-Length |
主体长度 |
|
Content-MD5 |
主体MD5校验和 |
|
Content-Range |
在整个资源中,实体表示的字节范围 |
|
Content-type |
主体对象类型 |
MD5:一种散列函数,用以提供消息的完整性保护。MD5即Message-Digest Algorithm 5(信息摘要算法5),是计算机广泛使用的散列算法之一(又译摘要算法、哈希算法)。对一段信息(Message)产生信息摘要(Message-Digest),以防止被篡改。用于确保信息传输完整一致。