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,体积非常小

概览图

注意

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

相关推荐
wx_lidysun3 小时前
Nextjs学习笔记
前端·react·next
无羡仙6 小时前
从零构建 Vue 弹窗组件
前端·vue.js
源心锁7 小时前
👋 手搓 gzip 实现的文件分块压缩上传
前端·javascript
源心锁7 小时前
丧心病狂!在浏览器全天候记录用户行为排障
前端·架构
GIS之路7 小时前
GDAL 实现投影转换
前端
phltxy8 小时前
从零入门JavaScript:基础语法全解析
开发语言·javascript
烛阴8 小时前
从“无”到“有”:手动实现一个 3D 渲染循环全过程
前端·webgl·three.js
BD_Marathon8 小时前
SpringBoot——辅助功能之切换web服务器
服务器·前端·spring boot
Kagol8 小时前
JavaScript 中的 sort 排序问题
前端·javascript
eason_fan8 小时前
Service Worker 缓存请求:前端性能优化的进阶利器
前端·性能优化