HTTP 协商缓存

Last-Modified与If-Modified-Since

如果没有任何缓存策略,那么浏览器会默认开启它。这个时候,我们发起请求,那么就会看在 response 里有一个字段 Last-Modified:

图片不重要,来自于网络

然后下一次请求的时候,浏览器会就把这个 Last-Modified 中的内容加到 request 中。变成 If-Modified-Since 字段的内容。

图片不重要,来自于网络

这个时候,服务器(一般使用 Nginx) 就会拿本地文件的信息与这个时间进行比较,如果相同的话,那么就会返回 304 。告诉浏览器从缓存中拿到信息。

Cache-Control 与 Expires

当然,我们还可以使用 Chche-Control 头来进行控制。可以在里面使用 max-age 来控制资源最长缓存时间

图片不重要,来自于网络

如果要强制不缓存,那么可以在 Cache-Control 中进行下面几种操作

  1. max-age=0
  2. 添加 private
  3. 给 Expires 设置为一个过去的时间点
# 可以在 nginx 的配置文件中这么修改
# 用正则过滤要使用 Expires 字段的资源,会自动同时设置 Cache-Control 与 Expires
location ~* \.(css|js|png)$ {
    expires 5d;
}

ETag 与 If-None-Match

也可以根据资源的内容来进行设置,如果资源内容完全一样,这个时候,我们就可以使用 ETag 来进行协商缓存了,第一次访问的时候,服务器会把内容的校验和放在 ETag 字段中,下次再请求的时候,则会向服务发送 If-None-Match 如果内容没有修改,那么就会返回 304. 要不返回最新内容

# ngnix 开启 etag 的方法

etag on;

图片不重要,来自于网络

图片不重要,来自于网络

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值