HTTP 缓存策略 分为 => 「强制缓存」 和 「协商缓存」
为什么需要 HTTP 缓存 呢 ? 👇
直接使用缓存速度 >> 远比重新请求快
缓存对象有那些呢 ?👇
「图片」 「JS文件」 「CSS文件」 等等

Response Header 中的Cache-Control属性Cache-Control 属性值有两种 :「no-cache」 和 「max-age= xxx」① 属性为「
no-cache」 时 👉 表示不需要 强制缓存 , 每次需要重新调接口 ;
② 属性为「
max-age= xxx」 时 👉 表示需要 强制缓存 , 缓存时长为xxx秒,超过时长需要重新请求 ;

「数据发生更新」 : 返回 状态码
200, 返回最新数据,取最新数据;
「数据未发生更新」 : 返回 状态码
304, 取缓存数据;
2 中形式第Ⅰ种形式 ,涉及参数 👇
Last-Modified :资源最后更新时间;If-Modified-Since : 传递给服务端的参数 ,判断与最新资源更新时间比较 👇「相等」 => 返回
304; 「不相等」 => 重新设置Last-Modified,返回200获取最新数据;

第Ⅱ种形式 ,涉及参数 👇
Etag :内容唯一标识符if-none-match :用来判断是否服务端的 Etag 是否相同
两种形式的区别 👇
Etag 可以精确到 毫秒 , 而 Last-Modified 只能判断秒级别的
上一篇:芯片后端开发基础知识(二)