简单梳理一下强缓存和协商缓存


图片来自网络


一、缓存(cache)是用来干什么的?

         主要是通过减少对服务器的访问,加快页面的加载速度,提升用户体验。

         满足一定条件下,客户端就不需要向服务器发送请求,而是直接在本地缓存中读取资源,这大大加快了获取资源的速度,也减小了服务器的压力。

         在第一次浏览器向服务器请求资源时,服务器就会在 Response Headers 里对缓存进行配置。如 cache-control: max-age=? public  no-store ...




二、强缓存?  

浏览器不会向服务器发送任何请求,而是直接在本地缓存中读取资源,并返回状态码200

强缓存的header参数

1.Expires:过期时间,如果设置了时间,则浏览器会在设置的时间内直接读取缓存,不再请求

2.Cache-control: 当cache-control里的 max-age=300(s),则意味着在这个请求后的五分钟之内再次加载相同资源,会直接命中强缓存; cache-control还有一些其他字段,在这里只简单介绍了max-age

图片来自网络




三、协商缓存?

上面说的强缓存简单来说就是给缓存资源设置一个过期时间,浏览器每次想要请求资源时都会判断一下这个资源是否过期,只在过期的时候才去向服务器请求资源。

如果浏览器在某次请求资源的时候发现本地缓存的资源过期了,这时候就会向服务器发送请求,并设置协商缓存

因此,协商缓存是需要浏览器向服务器发送请求的,服务器会根据 request header 里面的一些参数来判断是否命中协商缓存:如果命中,则返回 304 状态码,并且在 response header中携带新的参数,通知浏览器从缓存中读取资源;如果没有命中则返回 200 状态码,并且服务器会返回新的缓存资源给浏览器


协商缓存的header参数:

Etag / If-None-Match(每个资源的唯一标识字符串) :

1.Etag:(由服务器返回)用来帮助服务器控制浏览器端的缓存验证,如果文件被更改了 If-None-Match 就变了

2.If-None-Match: 当资源过期后,浏览器向服务器发送请求,并在 header 中带上 If-None-Match (值为Etag的值),服务器收到后判断该值与最初返回给浏览器的Etag值比对有没有发生变化,如果 变了 则说明文件被更改了,则返回新的资源和状态码200;没变 则返回状态码304通知浏览器从缓存中读取资源


Last-Modified / If-Modified-Since:

1.Last-Modified : (由服务器返回)服务器向浏览器发送的资源的最后修改时间

2.If-Modified-Since:  在浏览器向服务器发送请求时会携带 If-Modified-Since(值为Last-Modified的值)。服务器再次收到资源请求时,根据浏览器传过来If-Modified-Since资源在服务器上的最后修改时间判断资源是否有变化,如果没有变化则返回304 Not Modified,但是不会返回资源内容;如果有变化,就正常返回资源内容。当服务器返回304 Not Modified的响应时,response header中不会再添加Last-Modified的header,因为既然资源没有变化,那么Last-Modified也就不会改变,这是服务器返回304时的response header


你可能会思考,有了 Last-Modified ,为啥还需要 Etag?

1.一些文件也许会周期性的更改,但是他的内容并不改变(仅仅改变的修改时间),这个时候我们并不希望客户端认为这个文件被修改了,而重新GET;

2.某些文件修改非常频繁,比如在秒以下的时间内进行修改,(比方说1s内修改了N次),If-Modified-Since能检查到的粒度是s级的,这种修改无法判断(或者说UNIX记录MTIME只能精确到秒);

3.某些服务器不能精确的得到文件的最后修改时间。


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