失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 浏览器缓存——强缓存 协商缓存

浏览器缓存——强缓存 协商缓存

时间:2021-06-27 19:38:34

相关推荐

浏览器缓存——强缓存 协商缓存

目录

浏览器缓存:强缓存、协商缓存

#强缓存

#协商缓存

#补充

#拓展

浏览器缓存:强缓存、协商缓存

区别:强缓存不向服务器发送请求,协商缓存会发送请求至服务器

相同点:若命中,都直接从浏览器缓存加载资源,不从服务器加载

由响应头来控制缓存:

强缓存:Expires、Cache-Control

协商缓存(响应头+请求头):【Last-Modified + If-Modified-Since】、【ETag + If-None-Match】

#强缓存

1. Expires

内容:GMT格式字符串,存储的是一个绝对时间

过程:

第一次请求资源 ---》返回的响应携带Expires响应头 ---》浏览器将响应内容缓存

再次请求资源 ---》浏览器缓存中查找,若有则取出Expires时间与当前时间比较

---》在Expires之前则命中,读取资源

---》否则未命中,从服务器再次加载资源时,Expires被更新

风险:若用户手动修改浏览器时间,则会造成错误

2. Cache-Control

内容:绝对时间,以秒为单位。HTTP1.1版本提出

过程:

第一次请求资源 ---》返回的响应携带Cache-Control响应头 ---》浏览器将响应内容缓存

再次请求资源 ---》浏览器缓存中查找,若有则取出Cache-Control计算有效期,与当前时间比较

---》在有效期之前则命中,读取资源

---》否则未命中,从服务器再次加载资源时,缓存Cache-Control

配置项:

max-age:最大有效时间

must-revalidate:若超时,必须发送请求验证

no-cache:不使用强缓存(面试有考)

no-store:不使用缓存(面试有考)

public / private:代理是否可缓存

#协商缓存

1. Last-Modified + If-Modified-Since

内容:Last-Modified 存储的是资源文件最后一次更新的时间

过程:

第一次请求资源 ---》返回的响应携带Last-Modified响应头 ---》浏览器将响应内容缓存

再次请求资源 ---》将上次请求回的Last-Modified中内容,放入If-Modified-Since请求头中

---》向服务器发送请求

---》服务端判断时间,判断时间可知资源是否变化

---》未变化则返回304状态码,响应头中没有Last-Modified

---》变化则返回200状态码+资源文件+最新的Last-Modified以供浏览器更新

问题点:

* 资源修改但是内容没有实质性变化,例如文件周期性重写。仍然会将文件返回给浏览器

* 无法辨别一秒内多次修改的情况,不精确

2. ETag + If-None-Match

内容:ETag 存储的是服务器根据文件内容生成的唯一标识,用字符串表示。HTTP1.1版本提出

过程:

第一次请求资源 ---》返回的响应携带ETag响应头 ---》浏览器将响应内容缓存

再次请求资源 ---》将上次请求回的ETag中内容,放入If-None-Match请求头中

---》向服务器发送请求

---》服务端再次根据文件内容生成ETag,与收到的If-None-Match比较可知文件是否有变化

---》未变化则返回304状态码+新生成的ETag(浏览器更新),不返回资源

---》变化则返回200状态码+资源文件+最新的ETag以供浏览器更新

#补充

Q:刷新操作对缓存的影响?

A:正常操作(输入地址URL、跳转连接、前进后退等等):强缓存与协商缓存均有效

手动刷新(f5、点击菜单刷新、右键刷新):强缓存失效,协商缓存有效

强制刷新(ctrl + f5):强缓存、协商缓存均失效

#拓展

面试问题:前端存储有哪些?

(cookie、sessionStorage、localStorage、浏览器缓存、indexDB...)

如果觉得《浏览器缓存——强缓存 协商缓存》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。