--- title: Public-Key-Pins-Report-Only slug: Web/HTTP/Headers/Public-Key-Pins-Report-Only tags: - HPKP - HTTP - 头部 - 安全 translation_of: Web/HTTP/Headers/Public-Key-Pins-Report-Only ---
HTTP响应头部Public-Key-Pins-Report-Only用于设置在公钥固定不匹配时,发送错误信息到report-uri。 但和{{HTTPHeader("Public-Key-Pins")}}不同的是,即便公钥固定异常, 其允许浏览器继续访问服务器。

 

更多信息可以查看{{HTTPHeader("Public-Key-Pins")}}参考页面和HTTP Public Key Pinning文章

 

Header type {{Glossary("Response header")}}
{{Glossary("Forbidden header name")}} no

语法

Public-Key-Pins-Report-Only: pin-sha256="<pin-value>";
                             max-age=<expire-time>;
                             includeSubDomains;
                             report-uri="<uri>"

指令

pin-sha256="<pin-value>"
引号里面的是内容是以Base64编码的 {{Glossary("SPKI")}}(公钥) 指纹。你可以为多个不同的公钥都设定对应的pins。 一些浏览器将来可能也支持非SHA-256 的哈希算法。
max-age=<expire-time>
该指令对 Public-Key-Pins-Report-Only无效,客户端会忽略也不会缓存此头部。
 
includeSubDomains {{optional_inline}}
如果该选项被指定,该规则也会应用到网站的所有子域名
report-uri="<uri>"

     设置Pin验证失败报告的URL地址。这个指令应该和该头部一起使用,否则这个头部将是一个空操作。

 

例子

Public-Key-Pins-Report-Only:
  pin-sha256="cUPcTAZWKaASuYWhhneDttWpY3oBAkE3h2+soZS7sWs=";
  pin-sha256="M8HztCzM3elUxkcjR2S5P4hhyBNf6lHkmjAHKhpGPWE=";
  includeSubDomains;
  report-uri="https://www.example.org/hpkp-report"

在这个例子里面,pin-sha256="cUPcTAZWKaASuYWhhneDttWpY3oBAkE3h2+soZS7sWs=" 固定了该服务器的公钥.。第二个声明pin-sha256="M8HztCzM3elUxkcjR2S5P4hhyBNf6lHkmjAHKhpGPWE=" 也固定了服务器的备用公钥。同时通过includeSubDomains 的声明使得该设置对所有子域名都生效。最后, report-uri="https://www.example.org/hpkp-report" 则是定义了在验证失败时将异常信息发送到该服务器。

标准

Specification Title
{{RFC("7469", "Public-Key-Pins-Report-Only", "2.1")}} Public Key Pinning Extension for HTTP

浏览器兼容

{{Compat("http.headers.Public-Key-Pins-Report-Only")}}

更多