h5之缓存探索

对于web页面的缓存苦恼可归为两类(尤其微信内):1.js,css等资源缓存,2.入口文件html缓存

对于问题1是比较好解决的,用加query版本号(index.js?v=2019314)或打包md5文件名都可解决( index.a769sh7f9d.js),打包md5文件名的做法对现代前端项目是最常用的,但也带来一个问题,一旦发生问题2即入口文件html被缓存就会发生资源404的情况,具体原因就不详述了,重点是问题2

进入正题,要解决入口文件html缓存问题有两个方向(有很多乱七八糟的方法,并不能通过理论推演,实际也并无效果,暂不讨论):
1>nginx(或其他web容器服务端)做302,其原理是用户每次点击的链接都不会直接指向一个实际的html文件,302后才“抵达目的地”,这么做可以保证每次点击都是形成这样的链路,nginx302拿到的html一定是最新的
2>想办法让浏览器客户端不去缓存html文件,但怎么让它不缓存呢?能想到有两种手段,一个是加html加meta标签告诉浏览器不能缓存“我”,一个是服务端设置响应头加上no-cache

标签方法:

1.加meta标签

<meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate" />
<meta http-equiv="Pragma" content="no-cache" />
<meta http-equiv="Expires" content="0" />

2.在html标签中增加不存在的manifest文件链接,与加meta标签形式如出一辙,可归为一类

<html manifest="IGNORE.manifest">

服务端设置header:

#### kill cache
        add_header Last-Modified $date_gmt;
        add_header Cache-Control 'no-store, no-cache, must-revalidate, proxy-revalidate, max-age=0';
        if_modified_since off;
        expires off;
        etag off;

从上面可以看出,两种方案都涉及到了http协议,所以很有必要对http进行探索

一个很有意思的现象:一个项目中request header中带有cache-control: no-cache,而response里并没有带


image.png

来看一下MDN解释:


image.png

关于If-Modified-Since:


image.png

还有关于Expires头:


image.png

关于ETag:


image.png

这些基本上解释了上面ngnix add_header的一系列内容的具体意义

再偷一张完整的流程图:


image.png

为什么不选择meta标签?一方面meta标签只被部分浏览器支持,还有就是代理不解析HTML内容本身

所以综上所述,自古华山一条路,有效避免入口文件缓存的方法只有302和服务响应头

设置cache-control响应头后,客户端Response Headers

同时把etag,if_modified_since,expires 关掉,即响应头中不再有这些键值,重新进行缓存协商

测试缓存

当服务端及项目文件什么都不做时,第一次进入200,刷新后变成304,会被磁盘缓存,且在失效前每次都会被读
做了302后每次进入都会先有个302,再会有200,不会读取磁盘缓存
设置服务响应头后,每次请求都200,不会读取磁盘缓存

补充

加时间戳是否有效?时间戳并不会起到效果,这句话的意思是在于特殊应用场景,如果页面内跳转的话,时间戳是可以起到效果的,但是如果像微信分享链接出去,一个用户点击后把带时间戳的入口文件缓存到本地后,以后点击该链接时间戳也不会被刷新,这样是没有效果的,所以真正起到效果的是时间戳过期后的302,如果没有302,依然会从缓存中获取

附:1.https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Headers/Cache-Control
2.http://coolnuanfeng.github.io/webCache

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

推荐阅读更多精彩内容

  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,490评论 1 45
  • 浏览器对于请求资源, 流程如图所示: 可以看到浏览器的缓存机制分为两个部分: 1、当前缓存是否过期? 2、服务器中...
    zhoulujun阅读 1,206评论 0 3
  • 昨天测试iOS的收入页,切换账号后点击提现button直接跳转到了上次用户进入的收入页面,问题来了,切换了账号,又...
    倔强_2722阅读 26,178评论 1 20
  • Nginx简介 解决基于进程模型产生的C10K问题,请求时即使无状态连接如web服务都无法达到并发响应量级一万的现...
    魏镇坪阅读 2,005评论 0 9
  • 在我回家的路上,有小狗、小鸡、小鸟苍天大树,嫩绿的小草,还有爱唱歌的鸟儿,还有一个贪玩的我。 这条...
    93213dd6c7fc阅读 524评论 4 3