第六章、HTTP首部

<非常重要且恐怖的一章了>

HTTP报文=报文首部+(CR+LF)+报文实体

首部字段:
HTTP报文首部字段=(首部字段名:字段值)们
---类型*4:
  通用首部字段(请求&响应都可用);请求首部字段;响应首部字段;实体首部字段

-------------------------------------------------------通用首部字段-------------------------------------------------
Cache-Contorl:控制缓存行为,操作缓存的工作机制
  //Cache-Control:public/private/不缓存过期缓存:no-cache=Location|空(无参数表示可以使用缓存)
  /不缓存:no-store/对于公共缓存器,指定缓存期限和认证:s-maxage=秒数
  /接收缓存过期没超过指定时间的缓存:max-age=秒数
  /接收指定缓存时间内任有效的缓存:min-fresh=秒数
  /接收指定时间内的缓存,无论过期与否:max-stale=秒数
  /缓存服务器本地缓存了目标资源且不加载响应和有效性:only-if-cache
  /再次验证即将返回的缓存是否有效:must-ravalidate
  /要求缓存服务器收到客户端要求响应前检查返回的缓存:proxy-ravalidate
  /不允许改变缓存的媒体类型,防止缓存被压缩:no-transform
Connection:逐跳首部和连接的管理
  //逐跳首部/控制代理不再转发|转发前删除的首部字段:Connection:不再转发的首部字段
  //管理持久连接:Connection:close|Keep-Alive(非默认持久连接的HTTP版本指定)
Date:创建该报文的时间
Pragma:报文指令
  //客户端要求所有的中间服务器不返回缓存的资源:Pragma:no-cache
Trailer:首部一览,位于报文尾端
  //事先说明在报文主体中记录了哪些首部字段,该首部字段可应用在1.1版本分块传输编码时
Transfer-Encoding:报文主体的分块传输编码方式
Upgrace:协议的升级,用于检测HTTP协议是否可用高版本的协议通信,使用时需要再指定Connection:Upgrace
Via:经过的代理服务器的相关信息,用来追踪报文的转发,避免请求回环的发生
Warning:错误通知
  //通常会告知用户一些与缓存相关的错误
  //格式:Warning:[警告码][警告的主机:端口号]"[警告内容]"([日期时间])

《图解HTTP》阅读笔记--第六章--HTTP首部-LMLPHP

----------------------------------------------请求首部字段---------------------------------------------------
Accept:用户代理可处理的媒体类型
  //通知服务器用户代理指定的<多个>媒体联系和媒体类型间的相对优先关系
  //Accept: type/subtype1(类型);q=0.3,type/subtype2,type/subtype3;q=0.8,type/subtype4;q=0.5
  //逗号分隔类型与类型,分号分隔类型名与权重q,不写权重默认为1.0最大,权重可精确到小数点后三位。
Accept-Charset:优先的字符集
  //通知服务器用户代理指定的<多个>字符集和字符集间的相对优先关系
  //优先级由权重q决定,格式与Accept相同
Accept-Encoding:优先的内容编码
  //通知服务器用户代理指定的<多个>内容编码和内容编码间的相对优先关系
  //优先级由权重q决定,格式与Accept相同,同时可用“*”表示指定任意的内容编码
  //内容编码例子:gzip;compress;deflate;identify
Accept-Language:优先的自然语言
  //通知服务器用户代理指定的<多个>自然语言和自然语言间的相对优先关系
  //优先级由权重q决定,格式与Accept相同
  //例子:Accept-Language:zh-ch,zh;q=0.7,en-us,en;q=0.3
Authorization:Web/用户代理的认证信息
Expect:期待服务器的特定行为
  //HTTP1.1:Expect:100-Continue(状态码100 Continue)
  //服务器无法理解时会返回状态码417 Expectation Failed
From:用户的电子邮箱地址
Host:请求资源所在服务器(必须包含)
************if-xxxx样式的请求首部字段称为条件请求,服务器收到附带条件的请求时,当判断条件为真时才会执行请求
If-Match:比较值是否等于E-Tag实体标记
  //此时服务器无法使用弱ETag,≠则返回412 Precondtion Failed
  //若If-Match:*,服务器会忽略ETag,只要资源存在即可处理请求
If-None-Match:比较值是否不等于实体标记(与If-Match相反)
If-Range:资源未更新时发送实体Byte的范围请求
  //字段值若是跟ETag值或更新日期时间一致,那么就返回为范围内资源,反之则返回全体资源
If-Modified-Since:比较资源是否更新/更新时间
  //如果在字段指定的日期时间后资源发生了更新,服务器就会接受请求
If-Unmodified-Since:比较资源是否更新/更新时间(与If-Modified-Since相反)
  //如果在字段指定的日期时间后资源未发生更新,服务器就会接受请求
Max-Forwards:最大的传输直跳数(十进制),经过一个代理是数值减一,数值为0时返回响应
Proxy-Authorization:代理服务器要求客户端的认证信息(服务器和客户端的使用Authorization)
Range:获取实体的字节范围请求
Referer:告知服务器请求的原始资源的URI
TE:传输编码的优先级
  //除了指定传输编码之外,还可以指定伴随trailer字段的分块传输编码的方式--TE:trailer
User-Agent:将创建请求的HTTP客户端(代理或浏览器)程序的信息传给服务器

----------------------------------------------------响应首部字段-------------------------------------------------
Accept-Ranges:是否接受字节范围请求
  //Accepy-Ranges:bytes(接受)|none(不接受)
Age:推算资源创建经过的时间/秒
ETag:资源的对应匹配信息
  //资源更新时,对应的ETag值也会更新
  //相同URI不同的语言版本的资源是不同的,此时他们的ETag也是不同的
  //强弱ETag:强---资源发生一点点细微变化ETag都会变化;弱--用于提示资源是否相同,只有根本性变化会影响它,这时,弱ETag会在字段值最开始处附加W,例子:ETag:W/"usagi-1234"
Location:令客户端重定向至URI
  //配合3开头的状态字提供重定向的URI,几乎所有浏览器都会强制访问已提示的重定向资源
Proxy-Authenticate:代理服务器对客户端的认证信息
Retry-After:再次发起请求的时机要求(字段值为日期时间)
Server:HTTP服务器的安装信息
Vary:代理服务器缓存的管理信息
WWW-Authenticate:服务器对客户端的认证信息

--------------------------------------------------实体首部字段---------------------------------------------------
Allow:资源可支持的HTTP方法
Content-Encoding:适用的内容编程方式(gzip;compress;daflate;indetity)
  //内容编码是指在不丢失实体信息的前提下所进行的压缩
Content-Language:自然语言(中/英)
Content-Length:实体主体的大小/字节
Content-Location:报文主体返回资源的对应URI
Content-MD5:报文摘要
  //是一串由MD5算法生成的值,目的在于检查报文主体在传输中是否保持完整
Content-Range:位置范围
  //告知客户点作为响应返回的实体哪个部分符合范围请求
Content-Type:媒体类型
Expires:过期的日期时间
  //在指定的时间之前,响应的缓存副本会一直被保存,超期之后缓存服务器会再次向源服务器请求资源
Last-Modified:资源最后的修改日期时间

---------------------------------------------------其他非HTTP1.1首部字段----------------------------------------
Cookie/Set-Cookie/Content-Disposition-------132-140未看

05-11 17:56