http cache-control

news/2024/10/3 16:32:22 标签: http, 网络协议, 网络
http://www.w3.org/2000/svg" style="display: none;">

Cache-Control 是 HTTP 协议中用于控制缓存行为的重要头部字段。它定义了客户端和服务器端如何缓存资源,以及缓存的有效期。以下是关于 Cache-Control 的详细解释:

请求指令

  • max-age=
    • 指示客户端接受的响应最大年龄。如果缓存的响应超过这个年龄,将被视为过期。
  • max-stale[=]
    • 客户端愿意接受过期的响应。如果指定了秒数,表示客户端愿意接受超过过期时间至多这么多秒的响应。
  • min-fresh=
    • 客户端希望获取的响应至少还有指定秒数的新鲜时间。
  • no-cache
    • 强制缓存在使用任何缓存的响应之前,必须重新验证其有效性。
  • no-store
    • 禁止缓存存储任何关于客户端请求和服务器响应的信息。
  • no-transform
    • 禁止代理对响应进行任何转换(例如,压缩、修改图片格式等)。
  • only-if-cached
    • 客户端只接受已缓存的响应,并不想发起网络请求。
  • stale-if-error=
    • 如果新的请求失败,允许缓存在指定时间内提供过期的响应。
  • stale-while-revalidate=
    • 允许缓存返回一个过期的响应,同时在后台异步检查新的响应。

响应指令

  • max-age=
    • 指示响应可以在缓存中存储并被视为新鲜的最大时间。
  • s-maxage=
    • 类似于 max-age,但仅适用于共享缓存(例如,代理服务器)。
  • no-cache
    • 要求缓存每次在提供响应之前,都必须向服务器验证其有效性。
  • no-store
    • 完全禁止缓存存储响应,适用于包含敏感信息的响应。
  • no-transform
    • 禁止代理对响应进行任何转换。
  • public
    • 明确指出响应可以被任何缓存所存储,即使通常情况下不可缓存的响应。
  • private
    • 响应是为单个用户定制的,不应该被共享缓存存储。
  • must-revalidate
    • 一旦资源过期,缓存必须在使用之前向服务器验证其有效性。
  • proxy-revalidate
    • 类似于 must-revalidate,但仅适用于共享缓存。
  • immutable
    • 表示响应正文不会随时间改变,适用于永远不变的资源。
  • stale-while-revalidate=
    • 允许缓存在后台异步验证新鲜度时,提供一个过期的响应。
  • stale-if-error=
    • 如果在验证新鲜度时发生错误,允许缓存提供一个过期的响应。

这些指令提供了细粒度的控制,允许开发者根据具体需求优化缓存策略,提高网站性能和用户体验。

注意事项

  1. Cache-Control 会覆盖较旧的 Expires 头。

  2. 不同的指令可能会相互冲突,如 no-store 和 max-age 同时使用时,no-store 会优先生效。

  3. 浏览器可能会忽略某些缓存指令,特别是在隐私浏览模式下。

  4. 对于需要频繁更新的资源,可以考虑使用版本号或哈希值作为文件名的一部分,而不是依赖缓存控制。

  5. 在设置缓存策略时,需要平衡性能提升和内容时效性。

通过合理使用 Cache-Control,可以显著提高网站性能,减少服务器负载,同时确保用户能够及时获取最新内容。在实际应用中,应根据具体的业务需求和资源特性来选择合适的缓存策略。


http://www.niftyadmin.cn/n/5688673.html

相关文章

Golang | Leetcode Golang题解之第447题回旋镖的数量

题目: 题解: func numberOfBoomerangs(points [][]int) (ans int) {for _, p : range points {cnt : map[int]int{}for _, q : range points {dis : (p[0]-q[0])*(p[0]-q[0]) (p[1]-q[1])*(p[1]-q[1])cnt[dis]}for _, m : range cnt {ans m * (m - 1)…

【CSS】水平垂直居中

给父盒子设置属性 flex display: flex;写在父元素上这就是定义了一个伸缩容器justify-content:center 设置主轴对齐方式为居中,默认是横轴。子元素居中。align-items:center 设置纵轴对齐方式为居中,默认是纵轴。子元素居中。 给…

高质量的翻译如何提高界面可用性

翻译质量在提高界面可用性方面起着重要作用,特别是在全球受众使用的应用程序、网站和软件中。有效地翻译界面可以确保清晰度、连贯性和易用性,从而改善不同地区和语言的用户体验。以下是高质量翻译提高界面可用性的关键方法: 清晰直观的导航…

Go语言实现长连接并发框架 - 任务管理器

文章目录 前言接口结构体接口实现最后 前言 你好,我是醉墨居士,我们上篇博客实现了路由分组的功能,接下来这篇博客我们将要实现任务管理模块 接口 trait/task_mgr.go type TaskMgr interface {RouterGroupStart()StartWorker(taskQueue c…

基于微信的乐室预约小程序+ssm(lw+演示+源码+运行)

摘 要 随着社会的发展,社会的方方面面都在利用信息化时代的优势。互联网的优势和普及使得各种系统的开发成为必需。 本文以实际运用为开发背景,运用软件工程原理和开发方法,它主要是采用java语言技术和mysql数据库来完成对系统的设计。整个…

JavaScript while循环语句

While语句包括一个循环条件和一段代码块&#xff0c;只要条件为真&#xff0c;就不断循环执行代码块。 while(条件){语句;} var i0;while(i<100){console.log(i);i1;} 注意&#xff1a;所有的for循环都可以改写为while循环

暴力数据结构——AVL树

1.认识AVL树 AVL树最先发明的⾃平衡⼆叉查找树,AVL可以是⼀颗空树,或者具备下列性质的⼆叉搜索树&#xff1a; • 它的左右⼦树都是AV树&#xff0c;且左右⼦树的⾼度差的绝对值不超过1 • AVL树是⼀颗⾼度平衡搜索⼆叉树&#xff0c; 通过控制⾼度差去控制平衡 AVL树整体结点…

【EXCEL数据处理】000013 案例 EXCEL筛选与高级筛选。

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享一篇文章&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495; 目录 【EXCEL数据处理】000013 案例 EXCEL筛选与高级筛选。使用的软件&#…