浏览器缓存机制

浏览器缓存实际上就是对一些静态资源或是变化不多的资源进行本地缓存以加快访问速度的一种方式,善于利用缓存机制可以给网站性能带来非常大的提升,所以了解缓存机制原理是前端攻城师必须要掌握的。页面请求一个资源主要有3种情况:

1. 本地无缓存或强制刷新:客户端向服务器请求资源

2. 本地有缓存且未过期:客户端使用本地资源

3. 本地有缓存已过期:客户端重新请求服务器

首先介绍几个术语

HTTP 1.0:

Pragma:Pragma头域用来包含实现特定的指令,最常用的是Pragma:no-cache。在HTTP/1.1协议中,它的含义和Cache-Control:no-cache相同

Expires: 用来标识缓存失效时间,通常是一个时间值,如果是-1表示禁止缓存,如果存在Cache-Control的max-age,则此项被max-age覆盖

HTTP 1.1:

Cache-Control:主要值有public、private、no-cache、no-store、no-transform、must-revalidate、proxy-revalidate、max-age

(1)打开新窗口(_blank)

private、no-cache、must-revalidate 再次访问服务器

max-age 则在过期之前不会重复访问

(2)在地址栏回车

值为private或must-revalidate则只有第一次访问时会访问服务器,以后就不再访问。

值为no-cache,那么每次都会访问。

值为max-age,则在过期之前不会重复访问。

(3)按后退按扭

值为private、must-revalidate、max-age,则不会重访问,

值为no-cache,则每次都重复访问

(4)按刷新按扭

无论为何值,都会重复访问

public所有内容都将被缓存

private内容只缓存到私有缓存中

no-cache所有内容都不会被缓存

no-store所有内容都不会被缓存到缓存或 Internet 临时文件中

must-revalidation/proxy-revalidation如果缓存的内容失效,请求必须发送到服务器/代理以进行重新验证

max-age=xxx (xxx is numeric)缓存的内容将在 xxx 秒后失效, 这个选项只在HTTP 1.1可用, 并如果和Last-Modified一起使用时, 优先级较高

ETag/If-None-Match:'XXX':服务器资源的标识字符串,可以是md5也可以是时间戳,内容发生变化时,Etag也应该发生变化,以及浏览器请求时需要比较Etag的头信息

Last-Modified/If-Modified-Since: 服务器返回的文件最后修改时间,以及浏览器需要对比时提交的标识字符串

主要过程是:浏览器A请求服务器资源B

1. A发现本地没有缓存请求服务器下载资源B

2. 服务器返回资源B,并在头部提供了Cache-Control:max-age=60, Last-Modified:xxxx-xxx-xx,ETag:'abcdef';

3. 1分钟内A再次访问B,发现本地缓存未过期,直接使用本地资源,无需请求服务器

4. 1分钟后A再次访问B,发现缓存过期,向服务器发出请求,并带上If-Modified-Since:xxxx-xxx-xx和If-None-Match:'abcdef';

5. 服务器发现请求有If-Modified-Since和If-None-Match,对文件修改时间和Etag进行了对比

6. 如果文件有变化则返回200,并返回文件内容,并更新max-age, Last-Modified和ETag

7. 如果文件未更新,则返回304,告诉浏览器继续使用缓存文件,并更新max-age


问题1 Pragma,Expires和Cache-Control的区别是啥

Pragma和Expires是http 1.0的标准,支持http1.0和http1.1都可以使用,但是Expires存在服务器和客户端时间不同步的问题,所以一般采用:Cache-Control:max-age来代替Expires,但是只能在支持http1.1的浏览器使用

问题2 Last-Modified和Etag区别是啥

Last-Modified看似可以解决文件修改问题,但是存在文件内容没有被修改,修改时间却发生变化的可能,为了解决这个问你,Etag的出现能根据文件内容来准确保证缓存的正确性。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,968评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,601评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,220评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,416评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,425评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,144评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,432评论 3 401
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,088评论 0 261
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,586评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,028评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,137评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,783评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,343评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,333评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,559评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,595评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,901评论 2 345

推荐阅读更多精彩内容

  • 缓存一直是前端优化的主战场, 利用好缓存就成功了一半. 本篇从http请求和响应的头域入手, 让你对浏览器缓存有个...
    易斯大大阅读 770评论 0 1
  • 浏览器缓存机制,其实主要就是HTTP协议定义的缓存机制(如:Expires;Cache-control等)。但是也...
    raincoco阅读 279评论 0 0
  • 浏览器缓存机制,其实主要就是HTTP协议定义的缓存机制(如: Expires; Cache-control等)。但...
    RossWen阅读 721评论 0 21
  • http可以说是现在前端领域(甚至整个互联网)发展过程中使用最多的一个应用层协议。其传输层一般都是使用tcp协议来...
    Chyun阅读 1,110评论 0 1
  • 简单来说,浏览器缓存就是把一个已经请求过的资源拷贝一份存储起来,当下次需要该资源时,浏览器会根据缓存机制决定直接使...
    淘淘笙悦阅读 1,891评论 2 14