与缓存有关的信息保存在报文的header部分

两种方式判断浏览器缓存的新鲜度

1.服务器一开始将资源发送给客户端时,会把last-modified放在实体首部一起发送

客户端为资源标记上该信息,下次请求该资源时发送If-Modified-Since给服务端,服务端将其和Last-modified相比,如果一样,说明是新鲜的,返回304状态,如果不一样,返回200状态,说明资源已经被修改

2.通过ETag

Request

Cache-Control: max-age=0 以秒为单位
If-Modified-Since: Mon, 19 Nov 2012 08:38:01 GMT 缓存文件的最后修改时间。
If-None-Match: "0693f67a67cc1:0" 缓存文件的Etag值
Cache-Control: no-cache 不使用缓存
Pragma: no-cache 不使用缓存
   






Cache-control, if-Modified-Since, If-None-Match

Response

Cache-Control: public 响应被缓存,并且在多用户间共享
Cache-Control: private 响应只能作为私有缓存,不能在用户之间共享
Cache-Control:no-cache 提醒浏览器要从服务器提取文档进行验证
Cache-Control:no-store 绝对禁止缓存(用于机密,敏感文件)
Cache-Control: max-age=60 60秒之后缓存过期(相对时间)
Date: Mon, 19 Nov 2012 08:39:00 GMT 当前response发送的时间
Expires: Mon, 19 Nov 2012 08:40:01 GMT 缓存过期的时间(绝对时间)
Last-Modified: Mon, 19 Nov 2012 08:38:01 GMT 服务器端文件的最后修改时间
ETag: "20b1add7ec1cd1:0" 服务器端文件的Etag值





如果Cache-Control和Expires同时存在,优先使用Cache-control,这两者生效不需要和服务端交互

Cache-control和Expires生效时,直接使用缓存文件,无需使用ETag和If-modified-since

ETag

用来标识资源状态。服务器传ETag给客户端,客户端发送if-none-match,服务端将其与ETag比较。

使用原因是为了解决last-modified的某些问题:

1.某些文件的最后修改时间改变了但是文件没有改变,我们不希望客户端认为这个文件修改了

2.某些文件修改十分频繁,在秒以内修改,而last-modified只能精确到秒

如果ETag和Last-Modified同时使用,则要求他们同时通过验证才能返回304,否则返回200

按F5刷新浏览器和在地址栏里输入地址按回车是不一样的

前者:浏览器会去服务器端验证缓存

后者:浏览器直接使用有效缓存

HTTP 缓存



相关文章: