美文网首页http
http-报文首部

http-报文首部

作者: 井湾村夫 | 来源:发表于2018-10-02 16:52 被阅读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 错误通知
    • Cache-Control
        通过Cache-Control指令,就能操作缓存的工作机制。分为请求以及响应指令。
    请求指令 参数 说明
    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)
    • Connection
        - 控制不在转发给代理的首部字段


      hello.png

        - 管理持久连接(Keep-Alive)
        HTTP/1.1版本默认连接都是持久连接。为此,客户端会在持久连接上连续发送请求。如果服务器想断开时,直接指定Connection首部字段为Close。

    • Pragma
        Pragma是HTTP/1.1之前版本的历史遗留字段,仅作为与HTTP/1.0向后兼容而定义。

    Prama:no-cache

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

    • Upgrade
        首部字段Upgrade用来检测HTTP协议以及其他协议是否可使用更高版本进行通信,其参数值可用来指定一个完全不同的通信协议。


      image.png
    • Via
        使用首部字段Via是为了追踪客户端与服务器之间请求和响应报文的传输路径。报文经过代理或网关时,会先在首部字段Via中附加服务器的信息,然后在进行转发。
    请求首部(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】
    未完待续。。。。。

    相关文章

      网友评论

        本文标题:http-报文首部

        本文链接:https://www.haomeiwen.com/subject/qkaooftx.html