http缓存

概述

浏览器资源请求的时候,必不可少肯定会对资源进行缓存,这是对性能的一种必不可少的策略,为的就是带给用户更好的用户体验。

缓存

为什么缓存?

减少网络请求(网络请求不稳定性),让页面渲染更快

哪些资源可以被缓存?

静态资源(js css img)webpack/vite打包加contenthash根据内容生成hash

http缓存策略

强缓存

服务端在Response Headers中返回给客户端缓存标识字段(Cache-ControlExpires

Cache-Control的值取值

  • max-age:(常用)缓存的内容将在max-age秒后失效
  • no-cache:(常用)不要本地强制缓存,正常向服务端请求(只要服务端最新的内容)。需要使用协商缓存来验证缓存数据(Etag Last-Modified)
  • no-store: 不要本地强制缓存,也不要服务端做缓存,所有内容都不会缓存,强制缓存和协商缓存都不会触发
  • public: 所有内容都将被缓存(客户端和代理服务器都可缓存)
  • private: 所有内容只有客户端可以缓存

Expires

  • Expires:Thu, 31 Dec 2037 23:55:55 GMT(过期时间)
  • 已被Cache-Control代替

强制缓存的流程

  • 浏览器第一次请求资源,服务器返回资源和Cache-Control Expires
  • 浏览器第二次请求资源,会带上Cache-Control Expires,服务器根据这两个值判断是否命中强制缓存
  • 命中强制缓存,直接从缓存中读取资源,返回给浏览器
  • 未命中强制缓存,会带上If-Modified-Since If-None-Match,服务器根据这两个值判断是否命中协商缓存
  • 命中协商缓存,返回304,浏览器直接从缓存中读取资源
  • 未命中协商缓存,返回200,浏览器重新请求资源

流程图

协商缓存

属于服务端缓存策略,服务端判断客户端资源,是否和服务端资源一样如果判断一致则返回304(走缓存),否则返回200和最新资源, 服务端在Response Headers中返回给客户端缓存标识字段(Last-ModifiedEtag

  • Last-Modified和Etag会优先使用Etag,Last-Modified只能精确到秒级,如果资源被重复生成而内容不变,则Etag更准确
  • Last-Modified 服务端返回的资源的最后修改时间
  • If-Modified-Since 客户端请求时,携带的资源的最后修改时间(即Last-Modified的值)

协商缓存流程

示例

  • 通过Etag或Last-Modified命中缓存,没有返回资源,返回304,体积非常小

概览图

注意

强制缓存的优先级高于协商缓存

相关推荐
申阳6 小时前
Day 7:05. 基于Nuxt开发博客项目-首页开发
前端·后端·程序员
Crystal3286 小时前
App端用户每日弹出签到弹窗如何实现?(uniapp+Vue)
前端·vue.js
摸着石头过河的石头6 小时前
Service Worker 深度解析:让你的 Web 应用离线也能飞
前端·javascript·性能优化
用户4099322502126 小时前
Vue 3中watch侦听器的正确使用姿势你掌握了吗?深度监听、与watchEffect的差异及常见报错解析
前端·ai编程·trae
1024小神6 小时前
Xcode 常用使用技巧说明,总有一个帮助你
前端
政采云技术7 小时前
音视频通用组件设计探索和应用
前端·音视频开发
不爱吃糖的程序媛7 小时前
Electron 如何判断运行平台是鸿蒙系统(OpenHarmony)
javascript·electron·harmonyos
Hilaku7 小时前
我用AI重构了一段500行的屎山代码,这是我的Prompt和思考过程
前端·javascript·架构
Cxiaomu7 小时前
React Native App 自动检测版本更新完整实现指南
javascript·react native·react.js
IT_陈寒8 小时前
Vite性能优化实战:5个被低估的配置让你的开发效率提升50%
前端·人工智能·后端