【JS-11】什么是强缓存和协商缓存?

小课堂

分享人:禚洪宇

目录

1.背景介绍

2.知识剖析

3.常见问题

4.解决方案

5.编码实战

6.扩展思考

7.参考文献

8.更多讨论

1.背景介绍

浏览器缓存

浏览器缓存(browser caching)是浏览器储存的用户最近请求过的文档

优点:

  1. 减少冗余的数据传输
  2. 减少服务器的负担
  3. 加快客户端加载网页的速度

2.知识剖析

2.1 强制缓存

直接从缓存中获取资源而不经过服务器;与强制缓存有关的header有两个

  1. expires
  2. 它的值是GMT格式的绝对时间,如果发送请求的时间在expires设置的时间之前,那么缓存有效,否则就会发送请求至服务器来获取资源。

  1. cache-control:max-age=number
  2. 该字段主要是利用max-age值来进行判断,max-age是一个相对值,设置一个有效期。

    Cache-Control利用客户端时间进行判断,相对于Expires更安全

    cache-control字段的其它值:

  1. no-cache:不使用本地缓存,需要使用缓存协商
  2. no-store:禁止浏览器缓存数据,每次请求都会向服务器发送请求
  3. public:可以被所有的用户缓存,包括终端用户和CDN代理商
  4. private:只能被终端用户的浏览器缓存,不允许CDN等中继缓存服务器对其缓存

Tip:cache-control的优先级高于Expires

2.2 协商缓存

协商缓存是由服务器来判断缓存资源是否可用

1. Etag/If-None-Match

    Etag:(Entity Tag的缩写)可以是唯一标识资源的任何东西,配合cache-control使用

  1. 1 Etag:第一次请求,web服务器响应请求时,告诉浏览器当前资源在服务器中的唯一标识(生成规则由服务器决定)
  2. 2 If-None-Match:第二次请求携带,值为上一次请求返回的Etag值

2. Last-Modified/If-Modified-Since

二者的值都是GMT格式的时间字符串,具体过程:

  1. 浏览器第一次跟服务器请求一个资源,服务器在返回这个资源的同时,在respone的header加上Last-Modified的header,这个header表示这个资源在服务器上的最后修改时间
  2. 浏览器再次跟服务器请求这个资源时,在request的header上加上If-Modified-Since的header,这个header的值就是上一次请求时返回的Last-Modified的值

总结:

3. 常见问题

Last-Modified与Etag有什么区别?

4. 解决方案

  1. Last-Modified标注的最后修改时间只能精确到秒级
  2. 如果某些文件会被定期生成,当有时内容并没有任何变化,但Last-Modified却改变了,导致文件没法使用缓存

5.编码实战

6.扩展思考

如何对缓存进行性能优化?

https://www.zhihu.com/question/20790576

7.参考文献

参考一: http协商缓存VS强缓存

参考二: 浏览器的协商缓存与强缓存

参考三: 知乎

参考四: 浏览器缓存知识小结及应用

8.更多讨论

感谢观看

BY :禚洪宇