Cache-Control
        
        
          
                Baseline
                
                  Widely available
                
                
              
        
        
        
          
                
              
                
              
                
              
        
        
      
      This feature is well established and works across many devices and browser versions. It’s been available across browsers since 2015年7月.
Cache-Control 通用消息头字段,被用于在 http 请求和响应中,通过指定指令来实现缓存机制。缓存指令是单向的,这意味着在请求中设置的指令,不一定被包含在响应中。
| Header type | General header | 
|---|---|
| Forbidden header name | no | 
| CORS-safelisted response-header | yes | 
语法
指令格式具有以下有效规则:
- 不区分大小写,但建议使用小写。
- 多个指令以逗号分隔。
- 具有可选参数,可以用令牌或者带引号的字符串语法。
缓存请求指令
客户端可以在 HTTP 请求中使用的标准 Cache-Control 指令。
Cache-Control: max-age=<seconds> Cache-Control: max-stale[=<seconds>] Cache-Control: min-fresh=<seconds> Cache-control: no-cache Cache-control: no-store Cache-control: no-transform Cache-control: only-if-cached
缓存响应指令
服务器可以在响应中使用的标准 Cache-Control 指令。
Cache-control: must-revalidate Cache-control: no-cache Cache-control: no-store Cache-control: no-transform Cache-control: public Cache-control: private Cache-control: proxy-revalidate Cache-Control: max-age=<seconds> Cache-control: s-maxage=<seconds>
扩展Cache-Control指令
    拓展缓存指令不是核心 HTTP 缓存标准文档的一部分,使用前请注意检查兼容性!
Cache-control: immutable Cache-control: stale-while-revalidate=<seconds> Cache-control: stale-if-error=<seconds>
指令
>可缓存性
到期
- max-age=<seconds>
- 
设置缓存存储的最大周期,超过这个时间缓存被认为过期 (单位秒)。与 Expires相反,时间是相对于请求的时间。
- s-maxage=<seconds>
- 
覆盖 max-age或者Expires头,但是仅适用于共享缓存 (比如各个代理),私有缓存会忽略它。
- max-stale[=<seconds>]
- 
表明客户端愿意接收一个已经过期的资源。可以设置一个可选的秒数,表示响应不能已经过时超过该给定的时间。 
- min-fresh=<seconds>
- 
表示客户端希望获取一个能在指定的秒数内保持其最新状态的响应。 
- stale-while-revalidate=<seconds>实验性
- 
表明客户端愿意接受陈旧的响应,同时在后台异步检查新的响应。秒值指示客户愿意接受陈旧响应的时间长度。 
- stale-if-error=<seconds>实验性
- 
表示如果新的检查失败,则客户愿意接受陈旧的响应。秒数值表示客户在初始到期后愿意接受陈旧响应的时间。 
重新验证和重新加载
- must-revalidate
- 
一旦资源过期(比如已经超过 max-age),在成功向原始服务器验证之前,缓存不能用该资源响应后续请求。
- proxy-revalidate
- 
与 must-revalidate 作用相同,但它仅适用于共享缓存(例如代理),并被私有缓存忽略。 
- immutable实验性
- 
表示响应正文不会随时间而改变。资源(如果未过期)在服务器上不发生改变,因此客户端不应发送重新验证请求头(例如 If-None-Match或 If-Modified-Since)来检查更新,即使用户显式地刷新页面。在 Firefox 中,immutable 只能被用在https://transactions. 有关更多信息,请参阅这里。
其他
- no-transform
- 
不得对资源进行转换或转变。 Content-Encoding、Content-Range、Content-Type等 HTTP 头不能由代理修改。例如,非透明代理或者如Google's Light Mode可能对图像格式进行转换,以便节省缓存空间或者减少缓慢链路上的流量。no-transform指令不允许这样做。
- only-if-cached
- 
表明客户端只接受已缓存的响应,并且不要向原始服务器检查是否有更新的拷贝。 
示例
>禁止缓存
发送如下响应头可以关闭缓存。此外,可以参考Expires和Pragma消息头。
Cache-Control: no-store
缓存静态资源
对于应用程序中不会改变的文件,你通常可以在发送响应头前添加积极缓存。这包括例如由应用程序提供的静态文件,例如图像,CSS 文件和 JavaScript 文件。另请参阅 Expires 标题。
Cache-Control:public, max-age=31536000
需要重新验证
指定 no-cache 或 max-age=0, must-revalidate 表示客户端可以缓存资源,每次使用缓存资源前都必须重新验证其有效性。这意味着每次都会发起 HTTP 请求,但当缓存内容仍有效时可以跳过 HTTP 响应体的下载。
Cache-Control: no-cache
Cache-Control: max-age=0, must-revalidate
注意: 如果服务器关闭或失去连接,下面的指令可能会造成使用缓存。
Cache-Control: max-age=0
规范
| Specification | 
|---|
| HTTP Caching> # field.cache-control> | 
| HTTP Immutable Responses> # the-immutable-cache-control-extension> | 
浏览器兼容性
Loading…