强缓存和协商缓存的区别?

协商缓存和强缓存是 HTTP 缓存机制中的两种不同的策略,用于减少网络请求并提高网页加载速度。它们之间的主要区别在于缓存的验证方式服务器返回的响应头

强缓存:

  • 强缓存是基于过期时间(Expires)和缓存标识(Cache-Control)的策略。
  • 当浏览器发起请求时,会先检查本地缓存是否过期。如果缓存未过期,浏览器直接从本地缓存中获取资源,不发送请求到服务器。
  • 服务器通过设置响应头的 ExpiresCache-Control 字段来指定资源的过期时间或缓存规则。
  • 如果缓存过期,浏览器会发送请求到服务器,并在请求头中包含 If-Modified-SinceIf-None-Match 字段,以告知服务器上次获取资源时的时间或资源的标识。
  • 如果服务器返回 304 Not Modified 状态码,表示资源未发生变化,浏览器可以继续使用本地缓存,否则服务器返回新的资源。

协商缓存:

  • 协商缓存是基于实体标签(ETag)和最后修改时间(Last-Modified)的策略。
  • 当浏览器发起请求时,会发送资源的实体标签和最后修改时间等信息到服务器。
  • 服务器通过比较请求头中的实体标签(If-None-Match)或最后修改时间(If-Modified-Since)与资源的当前状态进行验证。
  • 如果资源未发生变化,服务器返回 304 Not Modified 状态码,浏览器可以使用本地缓存。如果资源有更新,服务器返回新的资源。

主要区别:

  • 强缓存是基于过期时间或缓存规则进行验证,而协商缓存是基于实体标签或最后修改时间进行验证。
  • 强缓存不与服务器进行通信,直接从本地缓存获取资源,而协商缓存需要与服务器进行通信以验证资源的状态。
  • 强缓存的响应头字段是 ExpiresCache-Control,而协商缓存的响应头字段是 ETagLast-Modified

通常情况下,浏览器会先使用强缓存进行验证,如果缓存过期,则使用协商缓存进行进一步的验证,以确保获取最新的资源。这样可以在一定程度上减少对服务器的请求,并提供更快的访问速度。

相关推荐
WeiQ_3 分钟前
解决phpstudy 8.x软件中php8.2.9没有redis扩展的问题
数据库·redis·缓存
Qrun3 分钟前
Windows11安装nvm管理node多版本
前端·vscode·react.js·ajax·npm·html5
中国lanwp4 分钟前
全局 npm config 与多环境配置
前端·npm·node.js
JELEE.1 小时前
Django登录注册完整代码(图片、邮箱验证、加密)
前端·javascript·后端·python·django·bootstrap·jquery
TeleostNaCl3 小时前
解决 Chrome 无法访问网页但无痕模式下可以访问该网页 的问题
前端·网络·chrome·windows·经验分享
前端大卫5 小时前
为什么 React 中的 key 不能用索引?
前端
你的人类朋友5 小时前
【Node】手动归还主线程控制权:解决 Node.js 阻塞的一个思路
前端·后端·node.js
JJCar6 小时前
【Cache缓存】cache的刷新
缓存·cache·多核数据一致性
小李小李不讲道理6 小时前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻6 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js