http

http-报文首部

2018-10-02  本文已影响14人  井湾村夫

  上次谈了谈http报文的状态码,这一次来说说报文的首部。我们都知道通过http协议传输的信息就是HTTP报文。报文又分为报文首部和报文主体,中间以CR+LF(空行隔开),类似于下图。在客户端和服务器进行http通信过程中,无论是请求还是响应都会使用首部字段,它能起到传递额外重要信息的作用。HTTP首部字段是由首部字段名和字段值构成的,中间以冒号“:”隔开。
  例如,在HTTP首部字段以Content-Type这个字段来表示报文主体的对象类型。

Content-Type:text/html,application/json

  就上述实例来看,首部字段名为Content-Type,自符串text/html是字段值。

若HTTP首部字段重复会如何

  当HTTP报文首部中出现两个或两个以上具有相同首部字段名会怎么样?这种情况在规范内尚未明确,根据浏览器内部处理逻辑的不同,结果可能不一致。有些浏览器会优先处理第一次出现的首部字段,有些则会优先处理最后出现的首部字段。笔者亲自试验过safari 和谷歌这两款浏览器,基本都是优先处理第一次出现的首部字段。


image.png

  其中HTTP首部又可以分成四种:通用首部,请求首部,响应首部,实体首部。

通用首部(General-Header Fields)

  请求报文和响应报文都会使用的首部。

首部字段 说明
Cache-Control 控制缓存的行为
Connection 逐跳首部,连接的管理
Date 创建报文的日期时间
Pragma 报文指令
Trailer 报文末端的首部一揽
Transfer-Encoding 指定报文主体的传输编码方式
Upgrade 升级为其他协议
Via 代理服务器的相关信息
Warning 错误通知
请求指令 参数 说明
no-cache 强制向服务器再次验证
no-store 不缓存请求或响应的任何内容
max-age=[秒] 必需 响应最大Age值
max-stale=[秒] 可省略 接受过期的响应
min-fresh=[秒] 必需 期望在指定时间内的响应仍有效
no-transform 代理不可更改媒体类型
only-if-cached 从缓存获取资源
cache-extension - 新指令标记(token)
响应指令 参数 说明
public 可向任意方提供响应缓存
private 可省略 仅向特定用户返回响应
no-cache 可省略 缓存前必须确定其有效性
no-store 不缓存请求或响应的任何内容
no-tranform 代理不可更改媒体类型
must-revalidate 可缓存但必须再向源服务器进行确认
proxy-revalidate 要求中间缓存服务器对缓存的响应有效性在进行确认
max-age=[秒] 必需 响应的最大Age值
s-maxage=[秒] 必需 公共缓存服务器响应最大Age值
cache-extension - 新指令标记(token)

Prama:no-cache

  该首部字段属于通用首部,但只用在客户端发送请求中。客户端会要求所有的中间服务器不返回缓存的资源。

请求首部(Request-Header Fields)

  从客户端向服务器发送请求报文时使用的首部。补充了请求的附加内容,客户端信息,响应内容相关优先级等信息。

首部字段 说明
Accept 用户代理可处理的媒体类型
Accept-Charset 优先的字符集
Accept-Encoding 优先的内容编码
Accept-Language 优先的语言(自然语言)
Authorization Web认证信息
Expect 期待服务器的特定行为
From 用户的电子邮箱地址
Host 请求资源的更新时间
if-Match 比较实体标记(ETag)
if-Modified-Since 比较资源的更新时间
if-None-Match 比较实体标记
if-Range 资源未更新时发送实体Byte的范围请求
if-Unmodified-Since 比较资源的更新时间(与if-modified-since相反)
Max-Forwards 最大传输逐跳数
Proxy-Authorization 代理服务器要求客户端的认证信息
Range 实体的字节范围请求
Referer 对请求中URI的原始获取方
TE 传输编码的优先级
User-Agent HTTP客户端程序的信息
响应首部(Response-Header Fields)

  从服务器端向客户端返回响应报文时使用的首部。补充了响应的附加内容,也会要求客户端附加额外的内容信息

首部字段 说明
Accept-Ranges 是否接受字节范围请求
Age 推算资源创建经过时间
ETag 资源的匹配信息
Location 零客户端重定向至指定URI
Proxy-Authenticate 代理服务器对客户端的认证信息
Retry-After 对再次发起请求的时机要求
Server HTTP服务器的安装信息
Vary 代理服务器缓存的管理信息
WWW-Authenticate 服务器对客户端的认证信息
实体首部(Entity-Header Fields)

  针对请求报文和响应报文的实体部分使用的首部。补充了资源内容更新时间等与实体有关的信息。

首部字段 说明
Allow 资源可支持的HTTP方法
Content-Encoding 实体主体适用的编码方式
Content-Language 实体主体的自然语言
Content-Length 实体主体的大小 单位 字节
Content-Location 替代对应资源的URI
Content-MD5 实体主体的报文摘要
Content-Range 实体主体的位置范围
Content-Type 实体主体的媒体类型
Expires 实体主体过期的日期时间
Last-Modified 资源的最后修改日期

参考【图解HTTP】
未完待续。。。。。

上一篇下一篇

猜你喜欢

热点阅读