浏览器强缓存和协商缓存

强缓存是什么?

强缓存是利用 http 的返回头中的 Expires 或者 Cache-Control 两个字段来控制的,用来表示资源的缓存时间

Expires

  • 缓存过期时间,用来指定资源到期的时间,是服务器端的具体的时间点。也就是说,Expires=max-age+请求时间,需要和 Last modified 结合使用。但它的优先级比Cache-Control 低。
    Expires 是Web服务器响应消息的头字段,在响应的HTTP请求时告诉浏览器在过期时间前,浏览器可以直接从浏览器缓存取数据,而无需再次请求

Cache-Control

  • Cache-Control 是一个相对时间,例如 Cache-Control:3600,代表着资源的有效期是 3600秒。由于是相对时间,并且都是与客户端时间比较,所以服务器与客户端时间偏差也不会导致问题。

Cache-Control 与Expires 可以在服务端配置同时启用或者启用任意一个,同时启用的时候Cache-Control优先级高。

  • 浏览器的缓存主要是为了提高访问效率,强制缓存,第一次访问一个网站的时候,里面的静态资源如图片、CSS、JS 、icon这些资源实际上是从服务器上下载的,刷新网页这个资源是没有必要在服务器上重新去请求的,像这样的资源,浏览器会默认是一些强制缓存,强制缓存当用户第二次访问的时候,它不会再服务器上重新下载资源了,同样返回200状态码,但这个资源会从浏览器的本地缓存里面去取,这种第二次取的缓存的状态就是一种强制缓存。

协商缓存是什么?

HTTP请求的状态码为 304

  • 和后台去协商资源,要不要对它进行缓存;
  • 如果是第一次请求,返回状态码200,在响应头中返回cache-Control,用来控制缓存使用的时间 / 方式(私有缓存和共享缓存),还会返回一个唯一标识 etag(可以理解为内容资源的一个hash或者一个唯一的标识)
  • 在第二次发起请求时,先查看 max-age, 如果过期了,在请求头设置 If-None-Match 等于刚刚 Etag的值,去后台对比,如果 etag 值相同,(或者对比Last Modified的一个时间)证明后端没更新,所以返回 304状态,浏览器接收到304状态之后,判断这个资源无变化,只需从本地把缓存的资源继续使用(也是协商缓存)。
相关推荐
不穿格子的程序员1 小时前
Redis篇4——Redis深度剖析:内存淘汰策略与缓存的三大“天坑”
数据库·redis·缓存·雪崩·内存淘汰策略
想搞艺术的程序员4 小时前
Go语言环形队列:原理剖析、编程技巧与核心优势
后端·缓存·golang
T1ssy4 小时前
深入解析Redis三大缓存问题:穿透、击穿、雪崩及解决方案
数据库·redis·缓存
木易 士心5 小时前
NestJS 核心揭秘:InstanceWrapper 的艺术与前端缓存新思路
前端·缓存
Haooog5 小时前
Redis面试题(不定时更新)
数据库·redis·缓存·面试
孙同学_5 小时前
【Linux篇】线程互斥、同步与线程池设计:原理与实践
数据库·redis·缓存
albert-einstein5 小时前
Nginx越界读取缓存漏洞CVE-2017-7529(参考peiqi文库以及gpt)
gpt·nginx·缓存
大佐不会说日语~5 小时前
Spring AI Alibaba 对话记忆丢失问题:Redis 缓存过期后如何恢复 AI 上下文
java·人工智能·spring boot·redis·spring·缓存
武子康5 小时前
Java-197 消息队列应用场景:缓存预热+限流排队+Redis Lua 扣库存+MQ 削峰填谷
java·redis·缓存·性能优化·消息队列·rabbitmq·java-rabbitmq
小小8程序员17 小时前
Redis-10
数据库·redis·缓存