强制缓存与协商缓存

强制缓存与协商缓存的区别

强制缓存和协商缓存是HTTP缓存机制的两种主要策略,它们在浏览器缓存控制方面有着不同的工作原理和应用场景。

强制缓存 (Strong Cache)

特点

  • 浏览器不向服务器发送请求,直接使用本地缓存

  • 完全由客户端控制缓存行为

实现方式

  • 通过以下HTTP响应头控制:

    • Cache-Control: max-age=3600 (缓存有效期,单位秒)

    • Expires: Wed, 21 Oct 2025 07:28:00 GMT (绝对过期时间)

工作流程

  1. 浏览器检查缓存是否存在且未过期

  2. 如果有效,直接使用缓存,不发送请求到服务器

  3. 如果过期,则进入协商缓存流程

适用场景

  • 静态资源(如图片、CSS、JS等不常变更的文件)

  • 可以长时间缓存的内容

协商缓存 (Conditional Cache)

特点

  • 浏览器会向服务器发送请求验证缓存是否有效

  • 需要客户端和服务器"协商"决定是否使用缓存

实现方式

  • 使用以下HTTP头部组合:

    • Last-Modified (服务器最后修改时间) + If-Modified-Since (客户端发送验证)

    • ETag (资源唯一标识) + If-None-Match (客户端发送验证)

工作流程

  1. 浏览器发送请求,携带If-Modified-SinceIf-None-Match

  2. 服务器验证资源是否修改:

    • 未修改:返回304 Not Modified,浏览器使用缓存

    • 已修改:返回200和新资源

适用场景

  • 频繁可能变更的资源

  • 需要实时性较高的内容

主要区别对比

特性 强制缓存 协商缓存
网络请求 不发送请求 发送验证请求
响应状态码 200 (from cache) 304 Not Modified
控制头 Cache-Control, Expires Last-Modified/ETag
带宽消耗 中(需要发送请求头)
实时性 低(直到过期) 高(每次验证)
典型应用 静态资源 动态内容

实际应用建议

  1. 对静态资源使用强制缓存并设置较长max-age

  2. 对HTML文档使用协商缓存

  3. 可通过文件名哈希实现"永久缓存"策略:

    • style.a1b2c3d4.css这样的文件名变化可视为新资源

    • 设置Cache-Control: max-age=31536000(1年)

  4. 组合使用示例:

复制代码
Cache-Control: public, max-age=604800
ETag: "33a64df551425fcc55e4d42a148795d9f25f89d4"
相关推荐
知识分享小能手7 小时前
微信小程序入门学习教程,从入门到精通,微信小程序常用API(上)——知识点详解 + 案例实战(4)
前端·javascript·学习·微信小程序·小程序·html5·微信开放平台
清灵xmf7 小时前
CSS field-sizing 让表单「活」起来
前端·css·field-sizing
文火冰糖的硅基工坊8 小时前
[光学原理与应用-480]:《国产检测设备对比表》
前端·人工智能·系统架构·制造·半导体·产业链
excel8 小时前
Qiankun 子应用生命周期及使用场景解析
前端
weixin_446260858 小时前
Django - 让开发变得简单高效的Web框架
前端·数据库·django
ObjectX前端实验室9 小时前
【react18原理探究实践】异步可中断 & 时间分片
前端·react.js
SoaringHeart9 小时前
Flutter进阶:自定义一个 json 转 model 工具
前端·flutter·dart
努力打怪升级9 小时前
Rocky Linux 8 远程管理配置指南(宿主机 VNC + KVM 虚拟机 VNC)
前端·chrome
brzhang9 小时前
AI Agent 干不好活,不是它笨,告诉你一个残忍的现实,是你给他的工具太难用了
前端·后端·架构
brzhang10 小时前
一文说明白为什么现在 AI Agent 都把重点放在上下文工程(context engineering)上?
前端·后端·架构