浏览器缓存策略的详细介绍(图文)

互联网 19-4-8
本篇文章给大家带来的内容是关于浏览器缓存策略的详细介绍(图文),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

为了提高站点的访问速度,使用缓存来优化。缓存主要分为 强缓存和协商缓存。

协商缓存

请求

响应

ETag:是一个可以与Web资源关联的记号(token)

如果文件被替换,就会生成唯一的etag。

替换前的文件

替换后的文件

PS: 如果是使用了多台服务器做负载均衡的话,会出现etag不一致问题。Apache 的默认ETag的值总是由文件的索引节点(Inode)、大小(Size)、最后修改时间(MTime)决定,我们只需要去掉Inode即可

强缓存

强缓存相比协商缓存更为彻底,在强缓存下浏览器不会对服务器发起请求。

强缓存:主要分为expires和cache-control

Expires: 表示存在时间,允许客户端在这个时间之前不去检查(发请求),等同max-age的 效果。但是如果同时存在,则被Cache-Control的max-age覆盖。 格式: Expires :时间,后面跟一个时间或者日期,超过这个时间后缓存失效。也就是浏览器发出请求之前,会检查这个时间是否失效,若失效,则浏览器会重新发出请求。

Cache-ControlCache-Control 在 HTTP 响应头中,用于指示代理和 UA 使用何种缓存策略。比如:

  • no-cache 为本次响应不可直接用于后续请求(在没有向服务器进行校验的情况下)
  • no-store 为禁止缓存(不得存储到非易失性介质,如果有的话尽量移除,用于敏感信息)
  • public为大家都可以缓存。
  • private为仅 UA 可缓存

设置为no-cache之后则不会再进行缓存。

题外话

在使用apache对浏览器缓存进行测试过程中发现。在不设置 cache-control的情况下,浏览器会根据自身的情况去取舍相关的缓存,可以从这查看。如果大家在服务器配置过程中发现,自己没有配置任何的缓存信息但是浏览器却缓存了资源就不用惊讶。

【相关推荐:JavaScript视频教程】

以上就是浏览器缓存策略的详细介绍(图文)的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: 缓存
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:JavaScript生成一次性密码(OTP)

相关资讯