强缓存
客户端第一次向服务器请求资源时,服务器返回某个资源的同时,添加某些头部信息,告诉客户端将资源保存在本地,并在未来的某个时点之前再次请求这个资源时,直接从本地获取就可以了。
【字段控制】
- Expires: 代表缓存资源的过期时间,一个绝对时间的GMT格式的时间字符串
浏览器再次请求这个资源时,会先从缓存中找到这个资源,然后获取Expires时间与当前的请求时间比较,如果Expires时间比当前浏览器的请求时间晚,说明缓存未过期,即命中缓存;
【比较】资源的 Expires 值 与 当前的请求时间
缺点:服务器返回的Expires时点是服务器上的时间,可能与客户端有时间差,时间差太大时可能造成缓存混乱。
- Cache-Control:max-age 缓存资源的最大生命周期
浏览器再次跟服务器请求同一个资源时,会先从缓存中找到这个资源,获取date(第一次资源返回的响应时间)和max-age并计算出一个有效期(date + max-age),然后再和浏览器请求时间比较最后判断是否命中缓存(逻辑同Expires);
【比较】资源的date 值 、max-age 与 当前的请求时间
Cache-Control描述的是相对时间,采用本地时间来计算资源的有效期,所以相比Expires更可靠。