设置浏览器缓存的几种方法:
  1. Last-Modified : 服务器上文件的最后修改时间
  2. Etag  : 文件标识
  3. Expiers : 本地缓存目录中文件过期的时间 ( 由服务器指定具体的时间 )
  4. Cache-control  缓存控制

浏览器端的缓存规则
  • 对于浏览器端的缓存规则是在HTTP协议头和 HTML 页面 Meat 标签中定义的。分别从 新鲜度 和 校验值两个维度来规定浏览器是否可以直接使用缓存中的副本,还是需要到原服务器获取更新的版本

    • 新鲜度 ( 过期机制 ) :也就是缓存副本有效期。
      1. 含有完整的过期时间控制头信息 ( HTTP协议报头),并仍在 有效期内
      2. 浏览器已经使用过这个缓存版本,并且在一个会话中已经检查过新鲜度
      3. 满足以上两个条件之一,则浏览器会直接从缓存中获取副本并渲染
    • 校验值 ( 验证机制 )  : 服务器返回资源的时候有时在控制头信息带上这个资源的实体标签 Etag ( Entity Tag) , 它可以用来作为浏览器再次请求过程的校验标识。如果发现校验标识不匹配,说明资源已经被修改或过期,浏览器需求重新获取资源内容。

注解:什么是Etag  
  • Etag 是 URL 的 Entity Tag , 用于标识 URL 对象是否改变,区分不同语言和Session等等。具体内部含义是服务器控制的,就像cookie那样。

    • 实例解析 : 当打开一个新的页面时 ,浏览器会向服务器发送一个http请求,服务器会生成一个 Etag 码 ( 标识当前被请求的文件) ,Etag 码放在 http 响应头 Response Headers中返回给浏览器

                  此时,服务器端返回的响应值为200,并发送了相应的网页内容,在http响应头中有 etag  消息头,值为ETag:   "87e2-524b6f1077980"  . 
                 然后刷新页面,浏览器再次向服务器发送http请求,此时请求头中包含 If-None-Match 消息头 ,它的值为If-None-Match :   "87e2-524b6f1077980"    . 该值的内容和先前第一次刷新返回的http响应中的 ETag 头完全一样。

                 此时,若 webserver 端的文件没有变化,这时  If-None-Match的值和 server 端的 etag 值相比完全相等,服务器认为客户端已经有最新的该文件的缓存了,服务器返回浏览器一个响应码为 "304"的http响应,它不包含任何响应的内容,只是提示客户端缓存的内容是最新的。
                若 webserver 端的文件发生变化,此时该文件对应的 etag 值就会发生变化,这时   If-None-Match的值和改变后的 etag 的值不相等,服务器就会发送一个新的文件内容给浏览器,同时返回改变后的 etag .
    • 注:etag码的生成和具体的服务器是有直接关联的,如果浏览器端前后两个http请求的接收端为不同的地址的服务器,此时返回的etag都是各自生成的不同的值,因此无法起到预期的缓存效果。

web浏览器下的缓存 - Etag的更多相关文章

  1. IE浏览器下ajax缓存导致数据不更新的解决方法

    摘自:http://www.iefans.net/ie-ajax-json-shuju-huancun/ 最近做设计的时候遇到一个小问题,当你用jquery的getjson函数从后台获取数据的时候,I ...

  2. get请求在ie浏览器下有缓存

    今天做项目的时候,数据库有新数据更新后,发现页面的行为却没有更新: 打断点调试的时候,发现程序也不进方法: 最终发现是因为请求数据的时候使用了get请求,而且在IE10下导致的: 注:IE浏览器中使用 ...

  3. IE浏览器下AJAX缓存问题导致数据不更新的解决办法

    一直知道使用ajax的时候,有的时候会出现数据缓存的问题,当时也没有深究,就是所有的简单粗暴的全部加上cache:false,或者使用在url处加上随机时间函数 今天无意间看见了为什么会出现缓存的原因 ...

  4. Web浏览器的缓存机制

    Web缓存的工作原理 所有的缓存都是基于一套规则来帮助他们决定什么时候使用缓存中的副本提供服务(假设有副本可用的情况下,未被销毁回收或者未被删除修改).这些规则有的在协议中有定义(如HTTP协议1.0 ...

  5. 006-优化web请求二-应用缓存、异步调用【Future、ListenableFuture、CompletableFuture】、ETag、WebSocket【SockJS、Stomp】

    四.应用缓存 使用spring应用缓存.使用方式:使用@EnableCache注解激活Spring的缓存功能,需要创建一个CacheManager来处理缓存.如使用一个内存缓存示例 package c ...

  6. 【Web缓存机制系列】2 – Web浏览器的缓存机制

    Web缓存的工作原理 所有的缓存都是基于一套规则来帮助他们决定什么时候使用缓存中的副本提供服务(假设有副本可用的情况下,未被销毁回收或者未被删除修改).这些规则有的在协议中有定义(如HTTP协议1.0 ...

  7. 【Web缓存机制系列】2 – Web浏览器的缓存机制-(新鲜度 校验值)

    Web缓存的工作原理 所有的缓存都是基于一套规则来帮助他们决定什么时候使用缓存中的副本提供服务(假设有副本可用的情况下,未被销毁回收或者未被删除修改).这些规则有的在协议中有定义(如HTTP协议1.0 ...

  8. IE浏览器下异步请求的缓存问题

    问题: 在做即时通讯时,需要提示用户有几条未读的提醒,这个是(如果有新的提示消息立马在浏览器无刷新提示)即时获取的.但我们的做法是,当用户点击未读信息进入到信息显示页面时重新获取下未读的提醒:但是在I ...

  9. ie浏览器下,get请求缓存问题

    1 使用get请求数据 1)Java代码 $.getJSON("sortShow!sortShow?time="+new Date().getTime(),function(){} ...

随机推荐

  1. php常见问题辨析(二)

    一:unset: 1.如果在函数中 unset() 一个全局变量,则只是局部变量被销毁,而在调用环境中的变量将保持调用 unset() 之前一样的值,如果您想在函数中 unset() 一个全局变量,可 ...

  2. 如何用eclispe远程调试tomcat--转载

    原文地址:http://jingyan.baidu.com/article/0320e2c1f4ef6b1b87507b06.html tomcat是一种非常常见的java web应用服务器,有时候服 ...

  3. JavaScript 之 弹出窗口总结

    一.javascript 控制窗口关闭及刷新 //关闭弹窗 <script language="javascript"> window.close(); </sc ...

  4. tornado简单的验证码

    1.html代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  5. python(7)– 类的反射

    python中的反射功能是由以下四个内置函数提供:hasattr.getattr.setattr.delattr,改四个函数分别用于对对象内部执行:检查是否含有某成员.获取成员.设置成员.删除成员. ...

  6. CentOS(十)--与Linux文件和目录管理相关的一些重要命令②

    在结束了第二期的广交会实习之后,又迎来了几天休闲的日子,继续学习Linux.在上一篇随笔 Linux学习之CentOS(十七)--与Linux文件和目录管理相关的一些重要命令① 中,详细记录了与Lin ...

  7. Redis中的关系查询(范围查询,模糊查询等...)

    本文部分转自于:http://blog.csdn.net/dc_726/article/details/42784317 本文对Redis如何保存关系型数据,以及如何对其匹配.范围.模糊查询进行举例讲 ...

  8. 【数论,找规律】Uva 11526 - H(n)

    原来做过的题再看还是没想出来,看来当时必然没有真正理解.这次回顾感觉理解更透彻了. 网上的题解差不多都是一个版本,而且感觉有点扯.根据n=20猜出来的? 好吧哪能根据一个就猜到那么变态的公式.其实这题 ...

  9. (转载)Java NIO:NIO原理分析(二)

          NIO中的两个核心对象:缓冲区和通道,在谈到缓冲区时,我们说缓冲区对象本质上是一个数组,但它其实是一个特殊的数组,缓冲区对象内置了一些机制,能够跟踪和记录缓冲区的状态变化情况,如果我们使用 ...

  10. 跟我一起学习VIM - The Life Changing Editor

    前两天同事让我在小组内部分享一下VIM,于是我花了一点时间写了个简短的教程.虽然准备有限,但分享过程中大家大多带着一种惊叹的表情,原来编辑器可以这样强大,这算是对我多年来使用VIM的最大鼓舞吧.所以分 ...