HTTP 请求头Cache-Control 详解

简介: HTTP 请求头Cache-Control 详解

大家好,我是阿萨。昨天我们学习了缓存机制。你了解缓存吗?了解了缓存基本原理。今天我们就详细学习下抓包的请求中Cache-Control 字段的所有设置的含义。
我们现在浏览器里随便抓一个请求的header。



图片中有个字段cache-control. 这个字段就是我们今天要讲解的。


一   cache-control 是干什么的?


cache-control 本身就是控制缓存行为的。通过给这个字段设置不一样的值,来控制缓存的工作机制。

这个字段请求和响应的header 都会包含这个字段。下面我们分别列举下请求里的可取值范围以及响应的可取值范围。


请求取值范围


类型
指令‍‍ 参数 说明
表示是否能缓存
no-cache
强制向源服务器再次验证
控制可执行缓存对象
no-store 不缓存请求或响应的任何内暗示请求中包含机密
指定缓存期限和认证
max-age = [ 秒] 必需 响应的最大Age缓存资源时间 < 指定值,客户端用缓存值。为0, 不使用缓存。
指定缓存期限和认证 max-stale( = [ 秒]) 可省略 接收已过期的响应
指定缓存期限和认证 min-fresh = [ 秒] 必需 期望在指定时间内的响应仍有效
指定缓存期限和认证 no-transform 代理不可更改媒体类型
指定缓存期限和认证 only-if-cached 从缓存获取资源
 cache-control的扩展 cache-extension - 新指令标记(token)


三 响应取值范围



指令 参数 说明
表示是否能缓存 public 可向任意方提供响应的缓其他用户也可利用缓存
表示是否能缓存 private 可省略 仅向特定用户返回响只对特定用户提供缓存
表示是否能缓存 no-cache 可省Location 缓存前必须先确认其有效性不缓存请求或响应的任何内容如果取值为Location,仅对Location不缓存,其他缓存。
控制可执行缓存对象 no-store

不缓存请求或响应的任何内容暗示响应中包含机密内容
指定缓存期限和认证 no-transform 代理不可更改媒体类型
指定缓存期限和认证 must-revalidate 可缓存但必须再向源服务器进行确认
指定缓存期限和认证 proxy-revalidate 要求中间缓存服务器对缓存的响应有效性再进行确认
指定缓存期限和认证 max-age = [ 秒] 必需 响应的最大Age缓存资源时间 < 指定值,客户端用缓存值。
指定缓存期限和认证 s-maxage = [ 秒] 必需‍‍ 公共缓存服务器响应的最大Age值
cache-control的扩展 cache-extension - 新指令标记(token)


你学会了吗?

相关文章
|
1月前
|
数据采集 JSON 网络协议
请你详细介绍一下HTTP请求头的常用格式
【2月更文挑战第21天】【2月更文挑战第65篇】请你详细介绍一下HTTP请求头的常用格式
|
3月前
|
存储 缓存 API
HTTP 请求的响应头部字段 Cache-Control 的值为 no-store 是什么意思
HTTP 请求的响应头部字段 Cache-Control 的值为 no-store 是什么意思
60 0
|
29天前
|
数据采集 缓存 前端开发
http和https请求服务器的时候在请求头部分都带什么到服务器呢?
HTTP和HTTPS请求头基本结构相似,HTTPS多了一层SSL/TLS加密。常见请求头如Accept(指定内容类型)、Authorization(身份验证)、Cookie(会话跟踪)、User-Agent(标识用户代理)等。HTTPS特有的头包括Upgrade-Insecure-Requests(升级到HTTPS)、Strict-Transport-Security(强制使用HTTPS)、Sec-Fetch-*(安全策略)和X-Content-Type-Options、X-Frame-Options等(增强安全性)。实际应用中,请求头会根据需求和安全策略变化。
20 0
|
1月前
|
数据采集 API
请解释什么是 HTTP 请求头,以及在爬虫中为什么要设置请求头?
请解释什么是 HTTP 请求头,以及在爬虫中为什么要设置请求头?
16 2
|
4月前
|
Python
HTTP请求头
这是一段描述如何处理HTTP请求头的Python代码。具体来说,这段代码的功能包括:
43 3
|
6月前
|
存储 缓存 网络协议
场景应用:常见的HTTP协议请求头有哪些?
场景应用:常见的HTTP协议请求头有哪些?
|
7月前
|
前端开发 Java
java在过滤器中为http请求加请求头header
现在有一个需求场景是,每一个请求我都需要在请求头里面加上token这个请求头,作为一种校验机制,传统的接口可以通过设置一个全局的变量,然后通过页面携带过来(大概就是先将我们的token放在session中,写一个服务用来获取session中的token,然后主页面用ajax调用接口,将token放在隐藏域中,然后将请求头放进来,用ajax方法,这里不想洗说了),但是有一种情况是通过页面传递的并不一定都会适用所有接口,比如上传和下载的接口有时候头里面就没有token参数,可能是上传和下载是用表单提交的 这个时候如何将请求头通过后台的方法加进来? 想到用过滤器,用后台方法强制加入请求头。
91 0
|
9月前
|
存储 缓存 JSON
解析http请求头、响应头。如何理解http缓存
解析http请求头、响应头。如何理解http缓存
217 0
|
缓存
HTTP 请求头Cache-Control 详解
大家好,我是阿萨。昨天我们学习了缓存机制。[你了解缓存吗?]了解了缓存基本原理。今天我们就详细学习下抓包的请求中Cache-Control 字段的所有设置的含义。
614 0
HTTP 请求头Cache-Control 详解
|
10天前
|
Java
java原生发送http请求
java原生发送http请求