一、浏览器缓存

Web 缓存能够减少延迟与网络阻塞,进而减少显示某个资源所用的时间。借助 HTTP 缓存,Web 站点变得更具有响应性。

(一)、缓存优点:

  • 减少不必要的数据传输,节省带宽
  • 减少服务器负担,提升网站性能
  • 加快客户端加载网页的速度,用户体验友好

(二)、缓存缺点:

  • 服务端资源更新后,客户端更新滞后

(三)、浏览器缓存主要有两类:

  1. 强制缓存
  2. 协商缓存

(四)、强缓存与协商缓存的区别 如图:

(五)、缓存机制原理:

浏览器第一次请求:

浏览器后续再进行请求时:

从上图可以知道浏览器在第一次请求发生后,再次请求时:

  • 浏览器在请求某一资源时,会先获取该资源缓存的header信息,判断是否命中强缓存(cache-control和expires信息),若命中直接从缓存中获取资源信息,包括缓存header信息;本次请求根本就不会与服务器进行通信;

二、强缓存

不会向服务器发送请求,直接从缓存中读取资源,请求返回状态码为 200.

强制缓存时,服务端会在 Response Headers 中的 cache-control 对缓存时间、缓存方式等进行定义,如下图:

或者: 

cache-control 字段

cache-control: max-age=xxxx,public

  • 客户端和代理服务器都可以缓存该资源;
  • 客户端在xxx秒的有效期内,如果有请求该资源的需求的话就直接读取缓存, statu code: 200
  • 如果用户做了刷新操作,就向服务器发起http请求

cache-control: max-age=xxxx,private

  • 只允许客户端可以缓存该资源;代理服务器不允许缓存
  • 客户端在xxx秒内直接读取缓存, statu code: 200

cache-control: max-age=xxxx,immutable

  • 客户端在xxx秒的有效期内,如果有请求该资源的需求的话就直接读取缓存, statu code:200
  • 即使用户做了刷新操作,也不向服务器发起http请求

cache-control: no-cache

  • 跳过设置强缓存,但是不妨碍设置协商缓存;一般如果你做了强缓存,只有在强缓存失效了才走协商缓存的,设置了no-cache就不会走强缓存了,每次请求都回询问服务端。

cache-control: no-store

  • 不缓存,这个会让客户端、服务器都不缓存,也就没有所谓的强缓存、协商缓存了。

补充:强制缓存在 header 中还有一个字段可以设置失效时间,即Expires,不过Expires 是HTTP 1.0的东西,现在默认浏览器均默认使用HTTP 1.1,所以它的作用基本忽略。

三、协商缓存

向服务器发送请求,服务器会根据这个请求的 Request Headers 的一些参数(etag 和 last-modified)来判断是否命中协商缓存,如果命中,则返回 304 状态码, 并带上新的 Request Headers 通知浏览器从缓存中读取资源;

协商缓存主要表现在 Response Headers 中的 etag 和 last-modified:

etag

  • 即文件hash,每个文件唯一

last-modified

  • 文件的修改时间,精确到秒

注意:

Response Headers 中的 etag、last-modified 在客户端重新向服务端发起请求时,会在 Request Headers 中换个key名:if-none-matched 和 if-modified-since

如下:

  // Response Headers

etag: 65597c1615681857158408944e

last-modified: Wed, 11 Sep 2019 06:20:13 GMT

  // Request Headers 变为

if-none-matched: 65597c1615681857158408944e

if-modified-since: Wed, 11 Sep 2019 06:20:13 GMT

两种缓存的共同点:都从客户端缓存中读取资源;区别是强缓存不会向服务器发请求,协商缓存会发请求

四、操作行为对缓存的影响

 

 

最新文章

  1. TODO:关于自媒体博客改名
  2. 捉襟见肘之UIImagePickerController 和自定义照相机
  3. css2
  4. [LeetCode] Subsets (bfs的vector实现)
  5. Mybatis的分页插件PageHelper
  6. ArcGIS Runtime SDK for WPF已不更新,后续将被ArcGIS Runtime SDK for .NET取代
  7. CTF---安全杂项入门第三题 这是捕获的黑客攻击数据包,Administrator用户的密码在此次攻击中泄露了,你能找到吗?
  8. DirectSound---3D环境
  9. AI - TensorFlow - 示例01:基本分类
  10. isolate demo
  11. Python3.7 练习题(二) 使用Python进行文本词频统计
  12. 关于Django启动创建测试库的问题
  13. UiAutomator 代码记录: 随机创建新联系人
  14. 《编写可维护的javascript》读书笔记(中)——编程实践
  15. 子页面iframe跨域执行父页面定义的JS方法
  16. Django-form组件和ModelForm组件
  17. OC Foundation框架—结构体
  18. GRUB 启动 WIN PE 镜像(ISO)
  19. 表单如何与Servlet控制器关联
  20. Android调用C#的WebService

热门文章

  1. [loj2091]小星星
  2. Redis | 第一部分:数据结构与对象 中篇《Redis设计与实现》
  3. Linux远程软件
  4. CF1264D1 Beautiful Bracket Sequence (easy version)
  5. Codeforces 1326F2 - Wise Men (Hard Version)(FWT+整数划分)
  6. Codeforces 1264F - Beautiful Fibonacci Problem(猜结论+找性质)
  7. 【机器学习与R语言】4-决策树
  8. 27-Roman to Integer-Leetcode
  9. Spring Cloud 2021.0.0 正式发布,第一个支持Spring Boot 2.6的版本!
  10. 避免UE4项目VS中误改源码.h文件导致编译时间长