HTTP的协商缓存和强制缓存

Web缓存机制主要分为两种类型:强制缓存 和 协商缓存。这两种缓存机制分别在不同的条件下发挥作用,共同确保了资源的有效缓存和更新。

 一、强制缓存

 强缓存就是本地缓存

 浏览器首次请求资源后,需要再次请求时,浏览器会首先获取该资源缓存的header信息,然后根据Cache-Controlexpires来判断该资源在本地缓存否过期。若没过期则直接从本地缓存中获取资源信息,浏览器就不再向服务器重新请求资源,如过期则需重新发送请求,重新缓存资源,更新缓存时间。

 强缓存是利用http请求头中的ExpiresCache-Control两个字段来进行控制,用来表示资源的缓存时间。

Expires

Expires是http1.0的规范,它的值是一个GMT格式的绝对时间字符串。

expires: Thu, 17 Nov 2022 10:06:35 GMT

Cache-Control

Cache-Control是http1.1中出现的,它的值是一个相对时间。

cache-control:max-age=31536000

Expires和Cache-Control的区别

这两个值都是用来控制缓存时间的,那它们两个有什么区别吗?

首先一个是绝对时间一个是相对时间。绝对时间跟系统时间改变而改变,这说明可以人为的改变该时间。而相对时间则是固定时间,是从请求到资源的那一刻开始算起。

两个时间可以共存,Cache-Control优先级更高

 二、协商缓存

 协商缓存是服务器用来确定缓存资源是否可用过期

 因为服务器需要向浏览器确认缓存资源是否可用,二者要进行通信,而通信的过程就是发送请求,所以在header中就需要有专门的标识来让服务器确认请求资源是否可以缓存访问,所以就有了下面两组header字段:

  • EtagIf-None-Match
  • Last-ModifiedIf-Modified-Since

Last-Modify/If-Modify-Since

Last-Modify

当浏览器第一次向服务器请求资源时,服务器会在该资源的请求头中加上Last-ModifyLast-Modify是该资源在服务器的最新修改时间,也就是说Last-Modify记录了该资源的最后一次创建、修改时间,保证服务器给浏览器的资源是最新的。

If-Modify-Since

然后当浏览器再次请求这个资源时,会在请求报文中带上If-Modify-Since

If-Modify-Since是浏览器上一次请求该资源时返回的Last-Modify时间,也就是说Last-ModifyIf-Modify-Since是同一个时间

当服务器收到If-Modify-Since时间后,会判断这个资源的当前最新修改时间If-Modify-Since时间是否相等,相等则说明浏览器缓存的资源已经是最新的了,服务器返回304状态码告诉浏览器资源已是最新不用更新

不相等则说明在浏览器没有请求的这段时间,这个资源已经进行了修改、更新,浏览器本地缓存的这个资源已经不是最新的了,这时候服务器重新返回该资源的最新版以及最新的Last-Modify时间。

Etag/If-None-Match

Etag/If-None-MatchLast-Modify/If-Modify-Since的处理逻辑一致,通俗讲都是第一次请求给个标识,然后下一次请求再把这个标识传回去,服务器判断资源改变没有,改变了就重新返回,没有改变就返回304,浏览器继续使用本地缓存。

既然都是一样的处理逻辑,那这两个有什么不同吗?

Etag/If-None-MatchLast-Modify/If-Modify-Since的不同

说白了Etag/If-None-Match就是用来弥补Last-Modify/If-Modify-Since的不足

  • Last-Modified标注只能精确到秒级,如果某些资源在1秒钟以内,被修改多次的话,它将不能准确标注文件的修改时间;
  • 某些资源会被定期生成,有时内容并没有变化,但Last-Modified记录的时间却改变了,导致资源刷新;
  • 有可能存在服务器没有准确获取资源的修改时间,或者与代理服务器时间不一致等情形。

Etag是服务器自动生成或者由开发者生成的资源在服务器的唯一标识符,能够更加准确的控制缓存

Etag/If-None-Match的优先级高于Last-Modify/If-Modify-Since

三、总结

  • 强制缓存:浏览器本地根据服务器设置的过期时间来判断是否使用缓存,未过期则从本地缓存里拿资源,已过期则重新请求服务器获取最新资源。
  • 协商缓存:浏览器本地每次都向服务器发起请求,由服务器来告诉浏览器是从缓存里拿资源还是返回最新资源给浏览器使用。
posted @ 2025-02-18 18:17  时光独醒  阅读(56)  评论(0)    收藏  举报