HTTP缓存<强缓存与协商缓存>

HTTP缓存

HTTP缓存的基本运作方式

请添加图片描述

  1. 浏览器查看自己有没有缓存,如果没有就向服务器索取
  2. 浏览器自己如果有,就要查看缓存是否过期
  3. 如果没有过期就使用,过期就向服务器进行验证
  4. 服务器告知没有过期就能继续使用,服务器告知已经过期就获取新的

总的来说:浏览器先看有无,再看浏览器自己是否过期,再向服务器看是否过期

强缓存

服务器通过响应头传来Catch-Control,设置了资源的过期时间

1. public           这些资源可以被任意对象缓存(如:客户端,代理服务器,等等)
2. private          这些资源只能在客户端缓存
3. max-age=xx       设置资源缓存的最大时间,超过时间表示缓存过期,请求会发到服务器(单位:秒)
4. no-cache         加载缓存资源前,强制发送请求到服务器进行“协商缓存”
5. no-store         不被做任何缓存

协商缓存

服务器返回资源和资源标识,客户端后续发送请求时,向服务器发送请求和资源标识,如果不是最新资源,服务器返回200、最新资源和最新资源标识;如果是最新资源,则服务器返回304,直接从缓存中拿资源。

资源标识:

  • Last-Modified:资源上一次修改的时间(了解)
  • ETag:资源对应唯一字符串

ETag:在客户端发起的请求,请求头会带有if-none-match,值为上一次响应的ETag,服务器将会对ETag进行对比,相同返回304,从本地缓存拿即可。

区别

二者主要的区别即为:强缓存不会向服务器发起请求,协商缓存则会

猜你喜欢

转载自blog.csdn.net/qq_47234456/article/details/125021401