zoukankan      html  css  js  c++  java
  • 浏览器缓存-2

      上一篇文章中,我们知道了使用Cache-Control:max-age 可以指定资源的过期时间。其实,Cache-Control 不仅仅只有这样一个值,而且它既可以在响应首部字段中也可以在请求首部字段中使用。下面总结几种常见的使用情况.

    一:Cache-Control 详谈

     1.Cache-Control: no-store;

      正如no-store名字所表达的那样,标记为no-store的响应会禁止浏览器对其缓存。

     2.Cache-Control:no-cache.

      标记为no-cache的响应实际上是可以储存在本地缓存中的。只是在与原始服务器进行新鲜度再验证之前,缓存不能将其提供给客户端使用。所以,这个首部使用 not-serve-from-cache-without-revalidation这个名字会更准确一些。

     4.Cache-Control:must-revalidata.

      这个响应首部告诉缓存,在事先没有跟原始服务器进行再验证的情况下,不能提供这个对象的过期缓存。(因为可以配置缓存,使其提供一些过期的资源以提高性能)。但缓存仍然可以随意提供新鲜的副本。

    二:客户端的新鲜度限制

      客户端浏览器可以使用Cache-Control请求首部来强化或放松对过期时间的限制。典型的,浏览器对 F5 和 Ctrl+F5 刷新就完全不一样。

      1.直接F5刷新。如果浏览器已缓存了资源,会带上 If-Last-Modified 和 If-None-Match 进行服务器再验证,对于大多数静态资源,通常会得到 304 即可以直接拿缓存。

      2.Ctrl+F5刷新。此请求报文不会包含 If-Last-Modified 和 If-None-Match ,即使浏览器中有可用的缓存,也要直接从源服务器中取资源。通常,浏览器请求字段会带上 Cache-Control:no-cache 和 Pragme:no-cache并得到 200 OK 的响应。

    三:应用

      StackOverflow中的一个提问,如何让指定的资源永远不被浏览器缓存。这个应用场景很常见的,观察到知乎首页由于会不断的推送新的内容所以禁止浏览器缓存。

     如下的设置可使绝大多数浏览器不对此资源进行缓存:

    Cache-Control: no-cache, no-store, must-revalidata
    Pragme: no-cache
    

     注:Pragme和Expires是为了兼容 HTTP 1.0 版本。

    github: https://github.com/CYanLong
  • 相关阅读:
    uva 1606 极角扫描
    Codeforces Round #304 (Div. 2) 题解
    Codeforces Round #306 (Div. 2) 题解
    Codeforces Round #299 (Div. 2) 题解
    树链剖分专题
    bzoj 1036: [ZJOI2008]树的统计Count
    bzoj 1007: [HNOI2008]水平可见直线
    bzoj 1003: [ZJOI2006]物流运输trans
    Codeforces Round #301 (Div. 2) 题解
    bzoj 1026: [SCOI2009]windy数
  • 原文地址:https://www.cnblogs.com/cyanlong/p/5726798.html
Copyright © 2011-2022 走看看