HTTP 协商缓存 Last-Modified,If-Modified-Since

浏览器第一次跟服务器请求一个资源,服务器在返回这个资源的同时,在respone header加上Last-Modified属性(表示这个资源在服务器上的最后修改时间):


浏览器再次跟服务器请求这个资源时,在request header上加上If-Modified-Since属性(该值就是上一次请求时返回的Last-Modified的值):

服务器再次收到资源请求时,根据浏览器传过来If-Modified-Since和资源在服务器上的最后修改时间判断资源是否有变化,如果没有变化则返回304 Not Modified,但是不会返回资源内容;如果有变化,就正常返回资源内容。

浏览器收到304的响应后,就会从缓存中加载资源。

如果协商缓存没有命中,浏览器直接从服务器加载资源时,Last-Modified Header在重新加载的时候会被更新,下次请求时,If-Modified-Since会启用上次返回的Last-Modified值。

一般来说,在没有调整服务器时间和篡改客户端缓存的情况下,这两个essay-header配合起来管理协商缓存是非常可靠的,但是有时候也会服务器上资源其实有变化,但是最后修改时间却没有变化的情况,就会影响协商缓存的可靠性。

相关推荐
不知道累,只知道类6 小时前
[故障复盘] 生产环境 HTTP 连接池耗尽导致的“服务假死”分析
网络·网络协议·http
_kank_7 小时前
HTTP 头部详细说明
http
就不掉头发9 小时前
HTTP基本知识
网络·网络协议·http
阿拉伯柠檬11 小时前
应用层协议HTTP
linux·网络·c++·网络协议·http
huangql52012 小时前
HTTP超文本传输协议:互联网的统一语言
网络·网络协议·http
_F_y13 小时前
应用层协议HTTP
网络·网络协议·http
是娇娇公主~13 小时前
HTTPS 常用密钥交换算法解析
网络协议·http·面试·https
Hi, how are you13 小时前
GyAn数字资产守护系统
python·安全·http·网络安全·信息与通信
qq_4634084213 小时前
React Native跨平台技术在开源鸿蒙中使用内置的`fetch` API或者第三方库如`axHarmony`来处理网络通信HTTP请求
javascript·算法·react native·react.js·http·开源·harmonyos
talenteddriver1 天前
web: http请求(自用总结)
前端·网络协议·http