图解HTTP学习笔记——第六章

声明:

本博客是本人在学习《图解 HTTP》后整理的笔记,旨在方便复习和回顾,并非用作商业用途。

如有侵权请告知,马上删除。

HTTP 首部

6.1 HTTP 报文首部

HTTP 协议的请求和响应报文中必定包含 HTTP 首部。 首部内容为客户端和服务器分别处理请求和响应提供所需要的信息。

HTTP 请求报文由方法、 URI、 HTTP 版本、 HTTP 首部字段等部分构成。

图解HTTP学习笔记——第六章_第1张图片

HTTP 响应报文由 HTTP 版本、 状态码(数字和原因短语) 、HTTP 首部字段 3 部分构成。

图解HTTP学习笔记——第六章_第2张图片

6.2 HTTP 首部字段

6.2.1 HTTP 首部字段传递重要信息

HTTP 首部字段是构成 HTTP 报文的要素之一。 在客户端与服务器之间以 HTTP 协议进行通信的过程中, 无论是请求还是响应都会使用首部字段。使用首部字段是为了给浏览器和服务器提供报文主体大小、 所使用的语言、 认证信息等内容。

6.2.2 HTTP 首部字段结构

HTTP 首部字段是由首部字段名和字段值构成的, 中间用冒号“:” 分隔(首部字段名: 字段值
)。

另外, 字段值对应单个 HTTP 首部字段可以有多个值。当 HTTP 报文首部中出现了两个或两个以上具有相同首部字段名时,有些浏览器会优先处理第一次出现的首部字段, 而有些则会优先处理最后出现的首部字段。

6.2.3 4 种 HTTP 首部字段类型

通用首部字段( General Header Fields):请求报文和响应报文两方都会使用的首部。

请求首部字段( Request Header Fields):从客户端向服务器端发送请求报文时使用的首部。 补充了请求的附加内容、 客户端信息、 响应内容相关优先级等信息。

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

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

6.2.4 HTTP/1.1 首部字段一览

通用首部字段表

首部字段名 说明
Cache-Control 控制缓存的行为
Connection 逐跳首部、 连接的管理
Date 创建报文的日期时间
Pragma 报文指令
Trailer 报文末端的首部一览
Transfer-Encoding 指定报文主体的传输编码方式
Upgrade 升级为其他协议
Via 代理服务器的相关信息
Warning 错误通知

请求首部字段表

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

响应首部字段表

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


实体首部字段表

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

6.2.5 非 HTTP/1.1 首部字段

在 HTTP 协议通信交互中使用到的首部字段不限于 RFC2616 中定义的 47 种首部字段, 还有 Cookie、 Set-Cookie 和 Content-Disposition等在其他 RFC 中定义的首部字段。

6.2.6 End-to-end 首部和 Hop-by-hop 首部

HTTP 首部字段将定义成缓存代理和非缓存代理的行为, 分成 2 种类型。

端到端首部( End-to-end Header):分在此类别中的首部会转发给请求 / 响应对应的最终接收目标, 且必须保存在由缓存生成的响应中, 另外规定它必须被转发。

逐跳首部( Hop-by-hop Header):分在此类别中的首部只对单次转发有效, 会因通过缓存或代理而不再转发。 HTTP/1.1 和之后版本中, 如果要使用 hop-by-hop 首部, 需提供 Connection 首部字段。

例如Connection、Keep-Alive、Proxy-Authenticate、Proxy-Authorization、Trailer、TE、Transfer-Encoding、Upgrade首部字段都为逐跳首部字段,其余为端到端首部字段。

6.3 HTTP/1.1 通用首部字段

6.3.1 Cache-Control

通过指定首部字段 Cache-Control 的指令, 就能操作缓存的工作机制。

指令的参数是可选的, 多个指令之间通过“,”分隔。 首部字段 CacheControl 的指令可用于请求及响应时。(Cache-Control: private, max-age=0, no-cache)

缓存请求指令表

指令 参数 说明
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-transform 代理不可更改媒体类型
must-revalidate 可缓存但必须再向源服务器进行确认
proxy-revalidate 要求中间缓存服务器对缓存的响应有效性再
进行确认
max-age = [ 秒] 必需 响应的最大Age值
s-maxage = [ 秒] 必需 公共缓存服务器响应的最大Age值
cache-extension - 新指令标记(token)

表示是否能缓存的指令

public 指令:明确表明其他用户也可利用缓存。

private 指令:响应只以特定的用户作为对象,对于其他用户发送过来的请求, 代理服务器则不会返回缓存。

no-cache 指令:防止从缓存中返回过期的资源。客户端发送的请求中如果包含 no-cache 指令,则表示客户端将不会接收缓存过的响应。 于是, “中间”的缓存服务器必须把客户端请求转发给源服务器。如果服务器返回的响应中包含 no-cache 指令, 那么缓存服务器不能对资源进行缓存。 源服务器以后也将不再对缓存服务器请求中提出的资源有效性进行确认, 且禁止其对响应资源进行缓存操作。若报文首部字段 Cache-Control 中对 no-cache字段名具体指定参数值, 那么客户端在接收到这个被指定参数值的首部字段对应的响应报文后, 就不能使用缓存。

no-store 指令:暗示请求(和对应的响应) 或响应中包含机密信息,规定缓存不能在本地存储请求或响应的任一部分。

指定缓存期限和认证的指令

max-age 指令:当客户端发送的请求中包含 max-age 指令时, 如果判定缓存资源的缓存时间数值比指定时间的数值更小, 那么客户端就接收缓存的资源。另外, 当指定 max-age 值为 0, 那么缓存服务器通常需要将请求转发给源服务器。当服务器返回的响应中包含 max-age 指令时, 缓存服务器将不对资源的有效性再作确认, 而 max-age 数值代表资源保存为缓存的最长时间。应用 HTTP/1.1 版本的缓存服务器遇到同时存在 Expires 首部字段的情况时, 会优先处理 max-age 指令, 而忽略掉 Expires 首部字段。HTTP/1.0 版本则相反。

s-maxage 指令:功能和 max-age 指令的相同,但 smaxage 指令只适用于供多位用户使用的公共缓存服务器。

min-fresh 指令:要求缓存服务器返回至少还未过指定时间的缓存资源。比如, 当指定 min-fresh 为 60 秒后, 过了 60 秒的资源都无法作为响应返回了。

max-stale 指令:指示缓存资源, 即使过期也照常接收。如果指令未指定参数值, 那么无论经过多久, 客户端都会接收响应;如果指令中指定了具体数值, 那么即使过期, 只要仍处于 max-stale指定的时间内, 仍旧会被客户端接收。

only-if-cached 指令:表示客户端仅在缓存服务器本地缓存目标资源的情况下才会要求其返回。若发生请求缓存服务器的本地缓存无响应, 则返回状态码 504 Gateway Timeout。

must-revalidate 指令:代理会向源服务器再次验证即将返回的响应缓存目前是否仍然有效。若代理无法连通源服务器再次获取有效资源的话, 缓存必须给客户端一条 504(Gateway Timeout) 状态码。且使用 must-revalidate 指令会忽略请求的 max-stale 指令。

proxy-revalidate 指令:要求所有的缓存服务器在接收到客户端带有该指令的请求返回响应之前, 必须再次验证缓存的有效性。

no-transform 指令:规定无论是在请求还是响应中, 缓存都不能改变实体主体的媒体类型。

Cache-Control 扩展(cache-extension token):可以扩展 Cache-Control 首部字段内的指令。

6.3.2 Connection

Connection 首部字段作用如下。

控制不再转发给代理的首部字段:在客户端发送请求和服务器返回响应内, 使用 Connection 首部字段, 可控制不再转发给代理的首部字段(即 Hop-by-hop 首部) 。

管理持久连接:HTTP/1.1 版本的默认连接都是持久连接。 为此, 客户端会在持久连接上连续发送请求。 当服务器端想明确断开连接时, 则指定Connection 首部字段的值为 Close。HTTP/1.1 之前的 HTTP 版本的默认连接都是非持久连接。 为此, 如果想在旧版本的 HTTP 协议上维持持续连接, 则需要指定Connection 首部字段的值为 Keep-Alive。

6.3.3 Date

首部字段 Date 表明创建 HTTP 报文的日期和时间。

6.3.4 Pragma

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

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

6.3.5 Trailer

首部字段 Trailer 会事先说明在报文主体后记录了哪些首部字段。

6.3.6 Transfer-Encoding

首部字段 Transfer-Encoding 规定了传输报文主体时采用的编码方式。

6.3.7 Upgrade

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

对于附有首部字段 Upgrade 的请求, 服务器可用 101 SwitchingProtocols 状态码作为响应返回。

6.3.8 Via

使用首部字段 Via 是为了追踪客户端与服务器之间的请求和响应报文的传输路径。报文经过代理或网关时, 会先在首部字段 Via 中附加该服务器的信息, 然后再进行转发。Via 首部是为了追踪传输路径, 所以经常会和 TRACE 方法一起使用。

6.3.9 Warning

HTTP/1.1 的 Warning 首部是从 HTTP/1.0 的响应首部(Retry-After) 演变过来的。 该首部通常会告知用户一些与缓存相关的问题的警告。

HTTP/1.1 警告码表

警告码 警告内容 说明
110 Response is stale(响应已过期) 代理返回已过期的资源
111 Revalidation failed(再验证失败) 代理再验证资源有效性时失败(服务
器无法到达等原因)
112 Disconnection operation(断开连接操
作)
代理与互联网连接被故意切断
113 Heuristic expiration(试探性过期) 响应的使用期超过24小时(有效缓存
的设定时间大于24小时的情况下)
199 Miscellaneous warning(杂项警告) 任意的警告内容
214 Transformation applied(使用了转换) 代理对内容编码或媒体类型等执行了
某些处理时
299 Miscellaneous persistent warning(持久
杂项警告)
任意的警告内容


6.4 请求首部字段

6.4.1 Accept

Accept 首部字段可通知服务器, 用户代理能够处理的媒体类型及媒体类型的相对优先级。可使用 type/subtype 这种形式, 一次指定多种媒体类型。 

若想要给显示的媒体类型增加优先级, 则使用 q= 来额外表示权重值, 用分号(;) 进行分隔。 权重值 q 的范围是 0~1(可精确到小数点后 3 位) , 且 1 为最大值。 不指定权重 q 值时, 默认权重为 q=1.0。

当服务器提供多种内容时, 将会首先返回权重值最高的媒体类型。

6.4.2 Accept-Charset

Accept-Charset 首部字段可用来通知服务器用户代理支持的字符集及字符集的相对优先顺序。 另外, 可一次性指定多种字符集。 与首部字段 Accept 相同的是可用权重 q 值来表示相对优先级。

6.4.3 Accept-Encoding

Accept-Encoding 首部字段用来告知服务器用户代理支持的内容编码及内容编码的优先级顺序。 可一次性指定多种内容编码。采用权重 q 值来表示相对优先级, 也可使用星号(*) 作为通配符,指定任意的编码格式。

编码格式例如:gzip、compress、deflate、identity。

6.4.4 Accept-Language

首部字段 Accept-Language 用来告知服务器用户代理能够处理的自然语言集(指中文或英文等) , 以及自然语言集的相对优先级。 可一次指定多种自然语言集。和 Accept 首部字段一样, 按权重值 q 来表示相对优先级。

6.4.5 Authorization

首部字段 Authorization 是用来告知服务器, 用户代理的认证信息(证书值) 。 通常, 想要通过服务器认证的用户代理会在接收到返回的401 状态码响应后, 把首部字段 Authorization 加入请求中。 共用缓存在接收到含有 Authorization 首部字段的请求时的操作处理会略有差异。

6.4.6 Expect

客户端使用首部字段 Expect 来告知服务器, 期望出现的某种特定行为。 

客户端可以利用该首部字段, 写明所期望的扩展。

6.4.7 From

首部字段 From 用来告知服务器使用用户代理的用户的电子邮件地址。 

6.4.8 Host

首部字段 Host 会告知服务器, 请求的资源所处的互联网主机名和端口号。 Host 首部字段在 HTTP/1.1 规范内是唯一一个必须被包含在请求内的首部字段。

6.4.9 If-Match

形如 If-xxx 这种样式的请求首部字段, 都可称为条件请求。 服务器接收到附带条件的请求后, 只有判断指定条件为真时, 才会执行请求。

首部字段 If-Match, 属附带条件之一, 它会告知服务器匹配资源所用的实体标记(ETag) 值。 这时的服务器无法使用弱 ETag 值。

服务器会比对 If-Match 的字段值和资源的 ETag 值, 仅当两者一致时, 才会执行请求。 反之, 则返回状态码 412 Precondition Failed 的响应。

还可以使用星号(*) 指定 If-Match 的字段值。 针对这种情况, 服务器将会忽略 ETag 的值, 只要资源存在就处理请求。

6.4.10 If-Modified-Since

首部字段 If-Modified-Since, 属附带条件之一, 它会告知服务器若 IfModified-Since 字段值早于资源的更新时间, 则希望能处理该请求。

而在指定 If-Modified-Since 字段值的日期时间之后, 如果请求的资源都没有过更新, 则返回状态码 304 Not Modified 的响应。

If-Modified-Since 用于确认代理或客户端拥有的本地资源的有效性。

6.4.11 If-None-Match

首部字段 If-None-Match 属于附带条件之一。 它和首部字段 If-Match作用相反。 用于指定 If-None-Match 字段值的实体标记(ETag) 值与请求资源的 ETag 不一致时, 它就告知服务器处理该请求。

6.4.12 If-Range

首部字段 If-Range 属于附带条件之一。 它告知服务器若指定的 IfRange 字段(ETag 值或者时间) 和请求资源的 ETag 值或时间相一致时, 则作为范围请求处理。 反之, 则返回全体资源。

6.4.13 If-Unmodified-Since

首部字段 If-Unmodified-Since 和首部字段 If-Modified-Since 的作用相反。 它的作用的是告知服务器, 指定的请求资源只有在字段值内指定的日期时间之后, 未发生更新的情况下, 才能处理请求。 

6.4.14 Max-Forwards

通过 TRACE 方法或 OPTIONS 方法, 发送包含首部字段 MaxForwards 的请求时, 该字段以十进制整数形式指定可经过的服务器最大数目。 服务器在往下一个服务器转发请求之前, Max-Forwards 的值减 1 后重新赋值。 当服务器接收到 Max-Forwards 值为 0 的请求时, 则不再进行转发, 而是直接返回响应。

6.4.15 Proxy-Authorization

接收到从代理服务器发来的认证质询时, 客户端会发送包含首部字段Proxy-Authorization 的请求, 以告知服务器认证所需要的信息。认证行为发生在客户端与代理之间。 

6.4.16 Range

对于只需获取部分资源的范围请求, 包含首部字段 Range 即可告知服务器资源的指定范围。无法处理该范围请求时, 则会返回状态码 200 OK 的响应及全部资源。

6.4.17 Refere

首部字段 Referer 会告知服务器请求的原始资源的 URI。

6.4.18 TE

首部字段 TE 会告知服务器客户端能够处理响应的传输编码方式及相对优先级。

6.4.19 User-Agent

首部字段 User-Agent 会将创建请求的浏览器和用户代理名称等信息传达给服务器。

6.5 响应首部字段

6.5.1 Accept-Ranges

首部字段 Accept-Ranges 是用来告知客户端服务器是否能处理范围请求, 以指定获取服务器端某个部分的资源。可指定的字段值有两种, 可处理范围请求时指定其为 bytes, 反之则指定其为 none。

6.5.2 Age

首部字段 Age 能告知客户端, 源服务器在多久前创建了响应。 字段值的单位为秒。

若创建该响应的服务器是缓存服务器, Age 值是指缓存后的响应再次发起认证到认证完成的时间值。 代理创建响应时必须加上首部字段 Age。

6.5.3 ETag

首部字段 ETag 能告知客户端实体标识。 它是一种可将资源以字符串形式做唯一性标识的方式。 服务器会为每份资源分配对应的 ETag值。当资源更新时, ETag 值也需要更新。

ETag 中有强 ETag 值和弱 ETag 值之分。

强 ETag 值, 不论实体发生多么细微的变化都会改变其值。

弱 ETag 值只用于提示资源是否相同。只有资源发生了根本改变, 产生差异时才会改变 ETag 值。 这时, 会在字段值最开始处附加 W/。

6.5.4 Location

使用首部字段 Location 可以将响应接收方引导至某个与请求 URI 位置不同的资源。

6.5.5 Proxy-Authenticate

首部字段 Proxy-Authenticate 会把由代理服务器所要求的认证信息发送给客户端。

6.5.6 Retry-After

首部字段 Retry-After 告知客户端应该在多久之后再次发送请求。 

6.5.7 Server

首部字段 Server 告知客户端当前服务器上安装的 HTTP 服务器应用程序的信息。 

6.5.8 Vary

首部字段 Vary 可对缓存进行控制。 源服务器会向代理服务器传达关于本地缓存使用方法的命令。

从代理服务器接收到源服务器返回包含 Vary 指定项的响应之后, 若再要进行缓存, 仅对请求中含有相同 Vary 指定首部字段的请求返回缓存。 即使对相同资源发起请求, 但由于 Vary 指定的首部字段不相同, 因此必须要从源服务器重新获取资源。

6.5.9 WWW-Authenticate

首部字段 WWW-Authenticate 用于 HTTP 访问认证。 它会告知客户端适用于访问请求 URI 所指定资源的认证方案(Basic 或是 Digest) 和带参数提示的质询(challenge) 。 

6.6 实体首部字段

6.6.1 Allow

首部字段 Allow 用于通知客户端能够支持 Request-URI 指定资源的所有 HTTP 方法。 当服务器接收到不支持的 HTTP 方法时, 会以状态码405 Method Not Allowed 作为响应返回。 与此同时, 还会把所有能支持的 HTTP 方法写入首部字段 Allow 后返回。

6.6.2 Content-Encoding

首部字段 Content-Encoding 会告知客户端服务器对实体的主体部分选用的内容编码方式。

6.6.3 Content-Language

首部字段 Content-Language 会告知客户端, 实体主体使用的自然语言 。

6.6.4 Content-Length

首部字段 Content-Length 表明了实体主体部分的大小(单位是字节) 。 

6.6.5 Content-Location

首部字段 Content-Location 给出与报文主体部分相对应的 URI。 和首部字段 Location 不同, Content-Location 表示的是报文主体返回资源对应的 URI。

6.6.6 Content-MD5

首部字段 Content-MD5 是一串由 MD5 算法生成的值, 其目的在于检查报文主体在传输过程中是否保持完整, 以及确认传输到达。

6.6.7 Content-Range

针对范围请求, 返回响应时使用的首部字段 Content-Range, 能告知客户端作为响应返回的实体的哪个部分符合范围请求。 字段值以字节为单位, 表示当前发送部分及整个实体大小。

6.6.8 Content-Type

首部字段 Content-Type 说明了实体主体内对象的媒体类型。 字段值用 type/subtype 形式赋值。

6.6.9 Expires

首部字段 Expires 会将资源失效的日期告知客户端。 缓存服务器在接收到含有首部字段 Expires 的响应后, 会以缓存来应答请求, 在Expires 字段值指定的时间之前, 响应的副本会一直被保存。

6.6.10 Last-Modified

首部字段 Last-Modified 指明资源最终修改的时间。

6.7 为 Cookie 服务的首部字段

Cookie 的工作机制是用户识别及状态管理。 Web 网站为了管理用户的状态会通过 Web 浏览器, 把一些数据临时写入用户的计算机内。 接着当用户访问该 Web 网站时, 可通过通信方式取回之前发放的 Cookie。

调用 Cookie 时, 由于可校验 Cookie 的有效期, 以及发送方的域、 路径、 协议等信息, 所以正规发布的 Cookie 内的数据不会因来自其他 Web 站点和攻击者的攻击而泄露。

Cookie 服务的首部字段

首部字段名 说明 首部类型
Set-Cookie 开始状态管理所使用的Cookie信息 响应首部字段
Cookie 服务器接收到的Cookie信息 请求首部字段


6.7.1 Set-Cookie

Set-Cookie 字段的属性

属性 说明
NAME=VALUE 赋予 Cookie 的名称和其值(必需项)
expires=DATE Cookie 的有效期(若不明确指定则默认为浏览器关闭前为止)
path=PATH 将服务器上的文件目录作为Cookie的适用对象(若不指定则默
认为文档所在的文件目录)
domain=域名 作为 Cookie 适用对象的域名 (若不指定则默认为创建 Cookie
的服务器的域名)
Secure 仅在 HTTPS 安全通信时才会发送 Cookie
HttpOnly 加以限制, 使 Cookie 不能被 JavaScript 脚本访问

expires 属性:Cookie 的 expires 属性指定浏览器可发送 Cookie 的有效期。

path 属性:Cookie 的 path 属性可用于限制指定 Cookie 的发送范围的文件目录。

domain 属性:通过 Cookie 的 domain 属性指定的域名可做到与结尾匹配一致。 

secure 属性:Cookie 的 secure 属性用于限制 Web 页面仅在 HTTPS 安全连接时, 才可以发送 Cookie。

HttpOnly 属性:Cookie 的 HttpOnly 属性是 Cookie 的扩展功能, 它使 JavaScript 脚本无法获得 Cookie。

6.7.2 Cookie

首部字段 Cookie 会告知服务器, 当客户端想获得 HTTP 状态管理支持时, 就会在请求中包含从服务器接收到的 Cookie。 接收到多个 Cookie 时, 同样可以以多个 Cookie 形式发送。

6.8 其他首部字段

6.8.1 X-Frame-Options

首部字段 X-Frame-Options 属于 HTTP 响应首部, 用于控制网站内容在其他 Web 网站的 Frame 标签内的显示问题。 其主要目的是为了防止点击劫持(clickjacking) 攻击。

首部字段 X-Frame-Options 有以下两个可指定的字段值。

DENY : 拒绝

SAMEORIGIN : 仅同源域名下的页面(Top-level-browsingcontext) 匹配时许可。 

6.8.2 X-XSS-Protection

首部字段 X-XSS-Protection 属于 HTTP 响应首部, 它是针对跨站脚本攻击(XSS) 的一种对策, 用于控制浏览器 XSS 防护机制的开关。

首部字段 X-XSS-Protection 可指定的字段值如下。

0 : 将 XSS 过滤设置成无效状态

1 : 将 XSS 过滤设置成有效状态

6.8.3 DNT

首部字段 DNT 属于 HTTP 请求首部, 其中 DNT 是 Do Not Track 的简称, 意为拒绝个人信息被收集, 是表示拒绝被精准广告追踪的一种方法。

首部字段 DNT 可指定的字段值如下。

0 : 同意被追踪

1 : 拒绝被追踪

6.8.4 P3P

首部字段 P3P 属于 HTTP 相应首部, 通过利用 P3P(The Platform forPrivacy Preferences, 在线隐私偏好平台) 技术, 可以让 Web 网站上的个人隐私变成一种仅供程序可理解的形式, 以达到保护用户隐私的目的。

要进行 P3P 的设定, 需按以下操作步骤进行。

步骤 1: 创建 P3P 隐私

步骤 2: 创建 P3P 隐私对照文件后, 保存命名在 /w3c/p3p.xml

步骤 3: 从 P3P 隐私中新建 Compact policies 后, 输出到 HTTP 响应中









 

你可能感兴趣的:(图解HTTP,http)