浏览器缓存机制详解(转)
同时参考的是W3CRFC2616规范中的
HTTP1.1/HEADER说明
利用HTTPCache来优化网站
缓存控制头Cache-Control
Cache-Control是最重要的规则。这个字段用于指定所有缓存机制在整个请求/响应链中必须服从的指令。这些指令指定用于阻止缓存对请求或响应造成不利干扰的行为。这些指令通常覆盖默认缓存算法。缓存指令是单向的,即请求中存在一个指令并不意味着响应中将存在同一个指令。
cache-control定义是:Cache-Control=“Cache-Control”“:”cache-directive。
表1展示了适用的值。
Cache-directive说明public所有内容都将被缓存private内容只缓存到私有缓存中no-cache所有内容都不会被缓存no-store所有内容都不会被缓存到缓存或Internet临时文件中must-revalidation/proxy-revalidation如果缓存的内容失效,请求必须发送到服务器/代理以进行重新验证max-age=xxx(xxxisnumeric)缓存的内容将在xxx秒后失效,这个选项只在HTTP1.1可用,并如果和Last-Modified一起使用时,优先级较高
表2表明在不同的情形下,浏览器是将请求重新发送到服务器还是使用缓存的内容。
表2.对cache-directive值的浏览器响应
Cache-directive打开一个新的浏览器窗口在原窗口中单击Enter按钮刷新单击Back按钮public浏览器呈现来自缓存的页面浏览器呈现来自缓存的页面浏览器重新发送请求到服务器浏览器呈现来自缓存的页面private浏览器重新发送请求到服务器第一次,浏览器重新发送请求到服务器;此后,浏览器呈现来自缓存的页面浏览器重新发送请求到服务器浏览器呈现来自缓存的页面no-cache/no-store浏览器重新发送请求到服务器浏览器重新发送请求到服务器浏览器重新发送请求到服务器浏览器重新发送请求到服务器must-revalidation/proxy-revalidation浏览器重新发送请求到服务器第一次,浏览器重新发送请求到服务器;此后,浏览器呈现来自缓存的页面浏览器重新发送请求到服务器浏览器呈现来自缓存的页面max-age=xxx(xxxisnumeric)在xxx秒后,浏览器重新发送请求到服务器在xxx秒后,浏览器重新发送请求到服务器浏览器重新发送请求到服务器在xxx秒后,浏览器重新发送请求到服务器
Cache-Control是关于浏览器缓存的最重要的设置,因为它覆盖其他设置,比如Expires和Last-Modified。另外,由于浏览器的行为基本相同,这个属性是处理跨浏览器缓存问题的最有效的方法。
过期头(Expires)
Expires头部字段提供一个日期和时间,响应在该日期和时间后被认为失效。失效的缓存条目通常不会被缓存(无论是代理缓存还是用户代理缓存)返回,除非首先通过原始服务器(或者拥有该实体的最新副本的中介缓存)验证。(注意:cache-controlmax-age和s-maxage将覆盖Expires头部。)
Expires字段接收以下格式的值:“Expires:Sun,08Nov200903:37:26GMT”。如果查看内容时的日期在给定的日期之前,则认为该内容没有失效并从缓存中提取出来。反之,则认为该内容失效,缓存将采取一些措施。表3-6表明针对不同用户操作的不同浏览器的行为。
表3.当用户打开一个新的浏览器窗口时的失效操作
Firefox3.5IE8Chrome3Safari4内容没有失效浏览器呈现来自缓存的页面浏览器重新发送请求到服务器。返回代码是200浏览器呈现来自缓存的页面浏览器呈现来自缓存的页面内容失效浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200
表4.当用户在原始浏览器窗口中单击Enter按钮时的失效操作
Firefox3.5IE8Chrome3Safari4内容没有失效浏览器呈现来自缓存的页面浏览器呈现来自缓存的页面浏览器重新发送请求到服务器。返回代码是304浏览器重新发送请求到服务器。返回代码是304内容失效浏览器重新发送请求到服务器。返回代码是200浏览器呈现来自缓存的页面浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200
表5.当用户按F5键刷新页面时的失效操作
Firefox3.5IE8Chrome3Safari4内容没有失效浏览器重新发送请求到服务器。返回代码是304浏览器重新发送请求到服务器。返回代码是304浏览器重新发送请求到服务器。返回代码是304浏览器重新发送请求到服务器。返回代码是304内容失效浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200
表6.当用户单击Back或Forward按钮时的失效操作
Firefox3.5IE8Chrome3Safari4内容没有失效浏览器呈现来自缓存的页面浏览器呈现来自缓存的页面浏览器呈现来自缓存的页面浏览器呈现来自缓存的页面内容失效浏览器呈现来自缓存的页面浏览器呈现来自缓存的页面浏览器呈现来自缓存的页面浏览器重新发送请求到服务器。返回代码是200
注意:所有浏览器都假定为使用默认设置运行。
控制文件是否有修改Last-Modified/E-Tag
Last-Modified实体头部字段值通常用作一个缓存验证器。简单来说,如果实体值在Last-Modified值之后没有被更改,则认为该缓存条目有效。ETag响应头部字段值是一个实体标记,它提供一个“不透明”的缓存验证器。这可能在以下几种情况下提供更可靠的验证:不方便存储修改日期;HTTP日期值的one-second解决方案不够用;或者原始服务器希望避免由于使用修改日期而导致的某些冲突。
不同的浏览器有不同的配置行为。表7-10表明针对不同用户操作的不同浏览器的行为。
表7.当用户打开一个新的浏览器窗口时的Last-ModifiedE-Tag操作:
Firefox3.5IE8Chrome3Safari4内容自上次访问以来没有被修改浏览器重新发送请求到服务器。返回代码是304浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是304浏览器重新发送请求到服务器。返回代码是304内容自上次访问以来已经被修改浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200
表8.当用户在原始浏览器窗口中单击Enter按钮时的Last-ModifiedE-Tag操作
Firefox3.5IE8Chrome3Safari4内容自上次访问以来没有被修改浏览器呈现来自缓存的页面浏览器呈现来自缓存的页面浏览器重新发送请求到服务器。返回代码是304浏览器重新发送请求到服务器。返回代码是304内容自上次访问以来已经被修改浏览器重新发送请求到服务器。返回代码是200浏览器呈现来自缓存的页面浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200
表9.当用户按F5键刷新页面时的Last-ModifiedE-Tag操作
Firefox3.5IE8Chrome3Safari4内容自上次访问以来没有被修改浏览器重新发送请求到服务器。返回代码是304浏览器重新发送请求到服务器。返回代码是304浏览器重新发送请求到服务器。返回代码是304浏览器重新发送请求到服务器。返回代码是304内容自上次访问以来已经被修改浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200
表10.没有缓存设置且用户单击Back或Forward按钮
Firefox3.5IE8Chrome3Safari4内容自上次访问以来没有被修改浏览器呈现来自缓存的页面浏览器呈现来自缓存的页面浏览器呈现来自缓存的页面浏览器呈现来自缓存的页面内容自上次访问以来已经被修改浏览器呈现来自缓存的页面浏览器呈现来自缓存的页面浏览器呈现来自缓存的页面浏览器重新发送请求到服务器。返回代码是200
注意:所有浏览器都假定使用默认设置运行。
不进行任何缓存相关设置
如果您不定义任何缓存相关设置,则不同的浏览器有不同的行为。有时,同一个浏览器在相同的情形下每次运行时的行为都是不同的。情况可能很复杂。另外,有些不该缓存的内容如果被缓存,将会导致安全问题。不同的浏览器有不同的行为。表11展示了不同的浏览器行为。
表11.没有缓存设置且用户打开一个新的浏览器窗口
Firefox3.5IE8Chrome3Safari4打开一个新页面浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200在原始窗口中单击Enter按钮浏览器重新发送请求到服务器。返回代码是200浏览器呈现来自缓存的页面。浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200按F5键刷新浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200单击Back或Forward按钮浏览器呈现来自缓存的页面。浏览器呈现来自缓存的页面。浏览器重新发送请求到服务器。返回代码是200浏览器重新发送请求到服务器。返回代码是200
关键结论
操作行为打开新窗口如果指定cache-control的值为private、no-cache、must-revalidate,那么打开新窗口访问时都会重新访问服务器。而如果指定了max-age值,那么在此值内的时间里就不会重新访问服务器,例如:Cache-control:max-age=5表示当访问此网页后的5秒内再次访问不会去服务器.在地址栏回车如果值为private或must-revalidate,则只有第一次访问时会访问服务器,以后就不再访问。如果值为no-cache,那么每次都会访问。如果值为max-age,则在过期之前不会重复访问。按后退按扭如果值为private、must-revalidate、max-age,则不会重访问,而如果为no-cache,则每次都重复访问.按刷新按扭无论为何值,都会重复访问.