为了正常的体验网站,请在浏览器设置里面开启Javascript功能!

浏览器缓存机制

2017-10-14 7页 doc 21KB 6阅读

用户头像

is_471618

暂无简介

举报
浏览器缓存机制浏览器缓存机制 文章分类:Java编程 Cache-Control Cache-Control 是最重要的规则。这个字段用于指定所有缓存机制在整个请求 / 响应链中必须服从的指令。这些指令指定用于阻止缓存对请求或响应造成不利干扰的行为。这些指令通常覆盖默认缓存算法。缓存指令是单向的,即请求中存在一个指令并不意味着响应中将存在同一个指令。 cache-control 定义是: Cache-Control = “Cache-Control” “:” cache-directive 。表 1 展示了适用的值。 Cache-...
浏览器缓存机制
浏览器缓存机制 文章分类:Java编程 Cache-Control Cache-Control 是最重要的规则。这个字段用于指定所有缓存机制在整个请求 / 响应链中必须服从的指令。这些指令指定用于阻止缓存对请求或响应造成不利干扰的行为。这些指令通常覆盖默认缓存算法。缓存指令是单向的,即请求中存在一个指令并不意味着响应中将存在同一个指令。 cache-control 定义是: Cache-Control = “Cache-Control” “:” cache-directive 。表 1 展示了适用的值。 Cache-directive 说明 public 所有都将被缓存 private 内容只缓存到私有缓存中 no-cache 所有内容都不会被缓存 所有内容都不会被缓存到缓存或 Internet 临时no-store 文件中 如果缓存的内容失效,请求必须发送到服务器 / must-revalidation/proxy-revalidation 代理以进行重新验证 缓存的内容将在 xxx 秒后失效 , 这个选项只在 max-age=xxx (xxx is numeric) HTTP 1.1 可用 , 并如果和 Last-Modified 一 起使用时 , 优先级较高 表 1. 常用 cache-directive 值 表 2 表明在不同的情形下,浏览器是将请求重新发送到服务器还是使用缓存的内容。 打开一个在原窗口中单击 单击 Back Cache-directive 新的浏览刷新 Enter 按钮 按钮 器窗口 浏览器 浏览器呈重新发浏览器呈浏览器呈现来自public 现来自缓送请求现来自缓缓存的页面 存的页面 到服务存的页面 器 第一次,浏览器重浏览器浏览器重新发送请求到服重新发浏览器呈新发送请private 务器;此后,浏览送请求现来自缓求到服务器呈现来自缓存到服务存的页面 器 的页面 器 浏览器浏览器重浏览器重重新发新发送请浏览器重新发送新发送请no-cache/no-store 送请求求到服务请求到服务器 求到服务到服务器 器 器 第一次,浏览器重浏览器浏览器重新发送请求到服重新发浏览器呈新发送请must-revalidation/proxy-revalidation 务器;此后,浏览送请求现来自缓求到服务器呈现来自缓存到服务存的页面 器 的页面 器 在 xxx 秒浏览器在 xxx 秒 后,浏览器在 xxx 秒后,浏重新发后,浏览器max-age=xxx (xxx is numeric) 重新发送览器重新发送请送请求重新发送 请求到服求到服务器 到服务请求到服 务器 器 务器 表 2. 对 cache-directive 值的浏览器响应 Cache-Control 是关于浏览器缓存的最重要的设置,因为它覆盖其他设置,比如 Expires 和 Last-Modified 。另外,由于浏览器的行为基本相同,这个属性是处理跨浏览器缓存问题的最有效的方法。 失效 Expires 头部字段提供一个日期和时间,响应在该日期和时间后被认为失效。失效的缓存条目通常不会被缓存(无论是代理缓存还是用户代理缓存)返回,除非首先通过原始服务器(或者拥有该实体的最新副本的中介缓存)验证。(注意: cache-control max-age 和 s-maxage 将覆盖 Expires 头部。) Expires 字段接收以下格式的值: “Expires: Sun, 08 Nov 2009 03:37:26 GMT” 。如果查看内容时的日期在给定的日期之前,则认为该内容没有失效并从缓存中提取出来。反之,则认为该内容失效,缓存将采取一些。表 3-6 表明针对不同用户操作的不同浏览器的行为。 Firefox 3.5 IE 8 Chrome 3 Safari 4 内容浏览器重新发送请浏览器呈现来自缓存浏览器呈现来自缓存浏览器呈现来自缓存没有求到服务器。返回的页面 的页面 的页面 失效 代码是 200 浏览器重新发送请求浏览器重新发送请浏览器重新发送请求浏览器重新发送请求内容到服务器。返回代码求到服务器。返回到服务器。返回代码到服务器。返回代码失效 是 200 代码是 200 是 200 是 200 表 3. 当用户打开一个新的浏览器窗口时的失效操作 Firefox 3.5 IE 8 Chrome 3 Safari 4 内容浏览器呈现浏览器重新发送请求到浏览器重新发送请求到浏览器呈现来自缓存的没有来自缓存的服务器。返回代码是 服务器。返回代码是 页面 失效 页面 304 304 浏览器重新发送请求到浏览器呈现浏览器重新发送请求到浏览器重新发送请求到内容服务器。返回代码是 来自缓存的服务器。返回代码是 服务器。返回代码是 失效 200 页面 200 200 表 4. 当用户在原始浏览器窗口中单击 Enter 按钮时的失效操作 Firefox 3.5 IE 8 Chrome 3 Safari 4 内容浏览器重新发送请求浏览器重新发送请浏览器重新发送请求浏览器重新发送请求没有到服务器。返回代码求到服务器。返回到服务器。返回代码到服务器。返回代码失效 是 304 代码是 304 是 304 是 304 浏览器重新发送请求浏览器重新发送请浏览器重新发送请求浏览器重新发送请求内容到服务器。返回代码求到服务器。返回到服务器。返回代码到服务器。返回代码失效 是 200 代码是 200 是 200 是 200 表 5. 当用户按 F5 键刷新页面时的失效操作 Firefox 3.5 IE 8 Chrome 3 Safari 4 内容没浏览器呈现来自浏览器呈现来浏览器呈现来自浏览器呈现来自缓存的页面 有失效 缓存的页面 自缓存的页面 缓存的页面 内容失浏览器呈现来自浏览器呈现来浏览器呈现来自浏览器重新发送请求到服务效 缓存的页面 自缓存的页面 缓存的页面 器。返回代码是 200 表 6. 当用户单击 Back 或 Forward 按钮时的失效操作 注意:所有浏览器都假定为使用默认设置运行。 Last-Modified/E-Tag Last-Modified 实体头部字段值通常用作一个缓存验证器。简单来说,如果实体值在 Last-Modified 值之后没有被更改,则认为该缓存条目有效。 ETag 响应头部字段值是一个实体标记,它提供一个 “ 不透明 ” 的缓存验证器。这可能在以下几种情况下提供更可靠的验证:不方便存储修改日期; HTTP 日期值的 one-second 解决方案不够用;或者原始服务器希望避免由于使用修改日期而导致的某些冲突。 不同的浏览器有不同的配置行为。表 7-10 表明针对不同用户操作的不同浏览器的行为。 Firefox 3.5 IE 8 Chrome 3 Safari 4 内容自上浏览器重新发送请浏览器重新发送浏览器重新发送请浏览器重新发送请次访问以求到服务器。返回代请求到服务器。返求到服务器。返回代求到服务器。返回代来没有被码是 304 回代码是 200 码是 304 码是 304 修改 内容自上浏览器重新发送请浏览器重新发送浏览器重新发送请浏览器重新发送请次访问以求到服务器。返回代请求到服务器。返求到服务器。返回代求到服务器。返回代来已经被码是 200 回代码是 200 码是 200 码是 200 修改 表 7. 当用户打开一个新的浏览器窗口时的 Last-Modified E-Tag 操作 Firefox 3.5 IE 8 Chrome 3 Safari 4 内容自上次浏览器呈浏览器重新发送请求浏览器重新发送请求浏览器呈现来自缓存访问以来没现来自缓到服务器。返回代码到服务器。返回代码的页面 有被修改 存的页面 是 304 是 304 内容自上次浏览器重新发送请求浏览器呈浏览器重新发送请求浏览器重新发送请求访问以来已到服务器。返回代码是 现来自缓到服务器。返回代码到服务器。返回代码经被修改 200 存的页面 是 200 是 200 表 8. 当用户在原始浏览器窗口中单击 Enter 按钮时的 Last-Modified E-Tag 操作 Firefox 3.5 IE 8 Chrome 3 Safari 4 内容自上浏览器重新发送请浏览器重新发送浏览器重新发送请浏览器重新发送请次访问以求到服务器。返回代请求到服务器。返求到服务器。返回代求到服务器。返回代来没有被码是 304 回代码是 304 码是 304 码是 304 修改 内容自上浏览器重新发送请浏览器重新发送浏览器重新发送请浏览器重新发送请次访问以求到服务器。返回代请求到服务器。返求到服务器。返回代求到服务器。返回代来已经被码是 200 回代码是 200 码是 200 码是 200 修改 表 9. 当用户按 F5 键刷新页面时的 Last-Modified E-Tag 操作 Firefox 3.5 IE 8 Chrome 3 Safari 4 内容自上次访浏览器呈现来自浏览器呈现来浏览器呈现来自浏览器呈现来自缓存的页问以来没有被缓存的页面 自缓存的页面 缓存的页面 面 修改 内容自上次访浏览器呈现来自浏览器呈现来浏览器呈现来自浏览器重新发送请求到服问以来已经被缓存的页面 自缓存的页面 缓存的页面 务器。返回代码是 200 修改 表 10. 没有缓存设置且用户单击 Back 或 Forward 按钮 注意:所有浏览器都假定使用默认设置运行。 不进行任何缓存相关设置 如果您不定义任何缓存相关设置,则不同的浏览器有不同的行为。有时,同一个浏览器在相同的情形下每次运行时的行为都是不同的。情况可能很复杂。另外,有些不该缓存的内容如果被缓存,将会导致安全问题。 不同的浏览器有不同的行为。表 11 展示了不同的浏览器行为。 Firefox 3.5 IE 8 Chrome 3 Safari 4 浏览器重新发送请浏览器重新发送浏览器重新发送请浏览器重新发送请打开一个新页求到服务器。返回代请求到服务器。求到服务器。返回求到服务器。返回面 码是 200 返回代码是 200 代码是 200 代码是 200 在原始窗口中浏览器重新发送请浏览器重新发送请浏览器重新发送请浏览器呈现来自单击 Enter 求到服务器。返回代求到服务器。返回求到服务器。返回缓存的页面。 按钮 码是 200 代码是 200 代码是 200 浏览器重新发送请浏览器重新发送浏览器重新发送请浏览器重新发送请按 F5 键刷新 求到服务器。返回代 请求到服务器。求到服务器。返回求到服务器。返回 码是 200 返回代码是 200 代码是 200 代码是 200 浏览器重新发送请浏览器重新发送请单击 Back 或 浏览器呈现来自缓浏览器呈现来自求到服务器。返回求到服务器。返回Forward 按钮 存的页面。 缓存的页面。 代码是 200 代码是 200 表 11. 没有缓存设置且用户打开一个新的浏览器窗口 注意:所有浏览器都假定使用默认设置运行。 最后 , 概括下关键的结论 : 如果指定 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, 则每次都重复访问 . 按刷新按无论为何值 , 都会重复访问 . 扭
/
本文档为【浏览器缓存机制】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。 本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。 网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
热门搜索

历史搜索

    清空历史搜索