`
liulanghan110
  • 浏览: 1078086 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

HTTP缓存ETAG和Last-Modified

 
阅读更多

基础知识 
        1) 什么是”Last-Modified”?  
        在浏览器第一次请求某一个URL时,服务器端的返回状态会是200,内容是你请求的资源,同时有一个Last-Modified的属性标记此文件在服务期端最后被修改的时间,格式类似这样:  
        Last-Modified: Fri, 12 May 2006 18:53:33 GMT  
        客户端第二次请求此URL时,根据 HTTP 协议的规定,浏览器会向服务器传送 If-Modified-Since 报头,询问该时间之后文件是否有被修改过:  
        If-Modified-Since: Fri, 12 May 2006 18:53:33 GMT  
        如果服务器端的资源没有变化,则自动返回 HTTP 304 (Not Changed.)状态码,内容为空,这样就节省了传输数据量。当服务器端代码发生改变或者重启服务器时,则重新发出资源,返回和第一次请求时类似。从而保证不向客户端重复发出资源,也保证当服务器有变化时,客户端能够得到最新的资源。  
        2) 什么是”Etag”?  
        HTTP 协议规格说明定义ETag为“被请求变量的实体值” (参见 —— 章节 14.19)。 另一种说法是,ETag是一个可以与Web资源关联的记号(token)。典型的Web资源可以一个Web页,但也可能是JSON或XML文档。服务器单独负责判断记号是什么及其含义,并在HTTP响应头中将其传送到客户端,以下是服务器端返回的格式:  
        ETag: "50b1c1d4f775c61:df3"  
        客户端的查询更新格式是这样的:  
        If-None-Match: W/"50b1c1d4f775c61:df3"  
        如果ETag没改变,则返回状态304然后不返回,这也和Last-Modified一样。本人测试Etag主要在断点下载时比较有用。 
      Last-Modified和Etags如何帮助提高性能? 
        聪明的开发者会把Last-Modified 和ETags请求的http报头一起使用,这样可利用客户端(例如浏览器)的缓存。因为服务器首先产生 Last-Modified/Etag标记,服务器可在稍后使用它来判断页面是否已经被修改。本质上,客户端通过将该记号传回服务器要求服务器验证其(客户端)缓存。  
        过程如下: 
                1. 客户端请求一个页面(A)。  
                2. 服务器返回页面A,并在给A加上一个Last-Modified/ETag。  
                3. 客户端展现该页面,并将页面连同Last-Modified/ETag一起缓存。  
                4. 客户再次请求页面A,并将上次请求时服务器返回的Last-Modified/ETag一起传递给服务器。  
                5. 服务器检查该Last-Modified或ETag,并判断出该页面自上次客户端请求之后还未被修改,直接返回响应304和一个空的响应体。

分享到:
评论

相关推荐

    http协议-缓存控制:etag If-None-Match / Last-Modified If-Modified-Since

    总结来说,Etag与If-None-Match以及Last-Modified与If-Modified-Since是HTTP缓存控制的关键组件,它们协同工作以减少不必要的数据传输,提升网络效率。通过分析提供的文件名称,我们可以推测这些Java类是实现这一...

    HTTP缓存头Last-Modified和ETag介绍

    在HTTP协议中,Last-Modified和ETag两个头部字段是用来验证缓存是否过期,确保浏览器使用的缓存是最新的。 Last-Modified是一个HTTP头部字段,它包含了服务器上文件的最后修改日期和时间。当浏览器首次请求一个资源...

    Caching HTTP Headers, Last-Modified and ETag

    标题 "Caching HTTP Headers, Last-Modified 和 ETag" 涉及到的是网络缓存中的两个关键概念,它们在优化网站性能、减少服务器负载以及提高用户体验方面扮演着重要角色。HTTP缓存机制允许浏览器存储先前请求过的资源...

    node-modified:修改后是一个简单的请求客户端来处理http本地缓存

    修改last-modified的HTTP规范,实现了last-modified , if-modified-since , etag , if-none-match 。概要Modified是根据构建的,并通过缓存支持对其进行修饰,因此,如果您熟悉请求,则几乎可以使用修改了。 var...

    Laravel开发-laravel-etag-middleware

    Last-Modified基于资源的修改时间,客户端同样可以使用If-Modified-Since头进行检查。Etag和Last-Modified相结合,可以提供更为精确的缓存验证机制。 总之,Laravel的Etag中间件是提升Web应用性能的一个实用工具,...

    最新大厂前端面试题-笔试题2.doc

    协商缓存的字段有 Last-Modified / If-Modified-Since 和 Etag / If-None-Match,其中 Etag / If-None-Match 的优先级比 Last-Modified / If-Modified-Since 高。 Last-Modified 字段,它的值是该资源文件在服务器...

    Etag和Expires.docx

    在后续请求中,客户端会在HttpRequest Header中发送If-Modified-Since报头,包含之前接收到的Last-Modified时间。如果服务器上的文件自上次请求后未被修改,服务器将返回304 Not Modified状态码,客户端则直接从本地...

    记录并显示网页的最后修改时间

    6. **ETag与If-Modified-Since** 除了`Last-Modified`,还有`ETag`头信息用于确认资源是否已改变。配合`If-Modified-Since`请求头,服务器可以更精确地控制资源更新。当`If-Modified-Since`的日期与服务器资源的`...

    Android http缓存实现

    HTTP缓存主要遵循HTTP协议中的缓存控制机制,如ETag、Last-Modified等头信息。下面将详细讨论Android中如何实现HTTP缓存。 1. **Android HTTP缓存的基本概念** - **HTTP缓存策略**:主要有两种,一是强缓存(Cache...

    浏览器的缓存机制1

    协商缓存通常涉及Last-Modified/If-Modified-Since和Etag/If-None-Match两个字段。Last-Modified是服务器返回资源的最后修改时间,If-Modified-Since是客户端再次请求时携带的Last-Modified值,用来告诉服务器资源的...

    web浏览器-缓存详解

    3. 缓存验证:若资源可能已更新,浏览器会发送一个带有If-None-Match或If-Modified-Since头的请求到服务器,服务器根据这些头信息判断资源是否改变,若无变化则返回304 Not Modified状态码,浏览器继续使用缓存;...

    浏览器之HTTP缓存的那些事

    - **Last-Modified/If-Modified-Since**: 用于比较服务器上的文件最后修改时间与客户端缓存副本的最后修改时间。 - **ETag/If-None-Match**: 提供了一个关于资源当前状态的标识符,用于判断资源是否发生变化。 ##...

    浏览器缓存机制

    浏览器缓存机制、Expires策略(http1.0)和Cache-control策略(http1.1)、Last-Modified/If-Modified-Since、ETag/If-None-Match

    浏览器缓存机制 mindMaster脑图与visio流程图

    2. 协商缓存:当强缓存无效时,浏览器会向服务器发送带有If-None-Match(ETag)或If-Modified-Since(Last-Modified)的请求头。ETag是服务器为每个资源分配的一个唯一标识,Last-Modified是资源的最后修改时间。...

    etag的讲解etag的讲解

    2. **配合Last-Modified**:同时使用Etag和Last-Modified,当Last-Modified可用时优先使用,因为其计算成本更低。 3. **考虑性能**:在大型应用中,可能需要优化Etag的生成策略,比如使用弱校验符(Weak Etag,以"W/...

    UIWebView离线缓存

    离线缓存机制主要依赖于HTTP协议中的缓存策略,包括Last-Modified和ETag等头信息。当UIWebView接收到一个网页请求时,它会检查本地是否有该页面的缓存副本。如果有,且服务器返回的缓存策略允许使用缓存,则...

    浏览器HTTP缓存运行机制流程图.zip

    浏览器在请求中添加`If-Modified-Since`头,包含上次资源的`Last-Modified`值。服务器比较这个时间,若资源未修改则返回304,否则返回新的资源和新的`Last-Modified`值。 HTTP缓存不仅涉及上述机制,还有其他策略如...

    彻底理解浏览器的缓存机制.docx

    - **If-Modified-Since**:客户端在请求时提供的最后修改时间,用于与服务器上的时间进行比较。 协商缓存的流程大致如下: 1. 浏览器发起请求,并附带先前存储的ETag或Last-Modified信息。 2. 服务器接收到请求后...

    Http页面缓存机制

    浏览器端缓存机制可以分为两类: Cache-Control、Etag、Expires、Last-Modified 和 Vary。这些规则可以控制浏览器缓存的行为,影响浏览器缓存的结果。 Cache-Control 是一种控制浏览器缓存的规则,它可以控制...

Global site tag (gtag.js) - Google Analytics