美文网首页IOSiOS学习笔记
webView网络缓存1 - ETag

webView网络缓存1 - ETag

作者: 子疯zp | 来源:发表于2018-03-15 14:45 被阅读12次
    什么是”Etag”? - Entity Tags

    HTTP 协议规格说明定义ETag为“被请求变量的实体值” 。另一种说法是,ETag是一个可以与Web资源关联的记号(token)。典型的Web资源可以一个Web页,但也可能是JSON或XML文档。服务器单独负责判断记号是什么及其含义,并在HTTP响应头中将其传送到客户端,以下是服务器端返回的格式:

        ETag: "50b1c1d4f775c61:df3"  
        客户端的查询更新格式是这样的:  
        If-None-Match: W/"50b1c1d4f775c61:df3"  
        如果ETag没改变,则返回状态304然后不返回,这也和Last-Modified一样。
    
    ETag应用:

    Etag由服务器端生成,客户端通过If-Match或者说If-None-Match这个条件判断请求来验证资源是否修改。常见的是使用If-None-Match请求一个文件的流程可能如下:

    ====第一次请求===
    1.客户端发起 HTTP GET 请求一个文件;
    2.服务器处理请求,返回文件内容和一堆Header,当然包括Etag(例如"2e681a-6-5d044840")(假设服务器支持Etag生成和已经开启了Etag).状态码200
    ====第二次请求===
    1.客户端发起 HTTP GET 请求一个文件,注意这个时候客户端同时发送一个If-None-Match头,这个头的内容就是第一次请求时服务器返回的Etag:2e681a-6-5d044840
    2.服务器判断发送过来的Etag和计算出来的Etag匹配,因此If-None-Match为False,不返回200,返回304,客户端继续使用本地缓存;
    流程很简单,问题是,如果服务器又设置了Cache-Control:max-age和Expires呢,怎么办?
    答案是同时使用,也就是说在完全匹配If-Modified-Since和If-None-Match即检查完修改时间和Etag之后,服务器才能返回304.(不要陷入到底使用谁的问题怪圈)

    为什么使用Etag请求头?

    Etag 主要为了解决 Last-Modified 无法解决的一些问题。
    1、一些文件也许会周期性的更改,但是他的内容并不改变(仅仅改变的修改时间),这个时候我们并不希望客户端认为这个文件被修改了,而重新GET;
    2、某些文件修改非常频繁,比如在秒以下的时间内进行修改,(比方说1s内修改了N次),If-Modified-Since能检查到的粒度是s级的,这种修改无法判断(或者说UNIX记录MTIME只能精确到秒)
    3、某些服务器不能精确的得到文件的最后修改时间;
    为此,HTTP/1.1引入了 Etag(Entity Tags).Etag仅仅是一个和文件相关的标记,可以是一个版本标记,比如说v1.0.0或者说"2e681a-6-5d044840"这么一串看起来很神秘的编码。但是HTTP/1.1标准并没有规定Etag的内容是什么或者说要怎么实现,唯一规定的是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和一个空的响应体。

    相关文章

      网友评论

        本文标题:webView网络缓存1 - ETag

        本文链接:https://www.haomeiwen.com/subject/oudhqftx.html