问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

浏览器缓存的介绍

发布网友 发布时间:2022-04-23 14:54

我来回答

2个回答

懂视网 时间:2022-05-14 15:37

本篇文章给大家带来的内容是关于浏览器缓存策略的详细介绍(图文),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

为了提高站点的访问速度,使用缓存来优化。缓存主要分为 强缓存和协商缓存。

协商缓存

主要分为last-modified、etag。下面我主要通过代码修改来表现各个缓存之间的区别。先讨论协商缓存。last-modified表示文件的修改日期,如果文件做了修改那就应该重新获取文件。last-modified是文件修改后根据服务器的时间生成。

屏幕快照 2019-04-03 下午9.56.29.png

如果我们修改了文件则会重新获取,status就为200

屏幕快照 2019-04-06 下午3.06.33.png

再次刷新就会返回304表示缓存已经是最新不需要再更新。
请求中会询问相关文件修改时间(If-Modified-Since)

请求

request.png

响应

屏幕快照 2019-04-06 下午3.07.44.png

ETag:是一个可以与Web资源关联的记号(token)

如果文件被替换,就会生成唯一的etag。

替换前的文件

request (1).png

替换后的文件

屏幕快照 2019-04-06 下午3.20.11.png

PS: 如果是使用了多台服务器做负载均衡的话,会出现etag不一致问题。Apache 的默认ETag的值总是由文件的索引节点(Inode)、大小(Size)、最后修改时间(MTime)决定,我们只需要去掉Inode即可

强缓存

强缓存相比协商缓存更为彻底,在强缓存下浏览器不会对服务器发起请求。

强缓存:主要分为expires和cache-control

Expires: 表示存在时间,允许客户端在这个时间之前不去检查(发请求),等同max-age的 效果。但是如果同时存在,则被Cache-Control的max-age覆盖。 格式: Expires :时间,后面跟一个时间或者日期,超过这个时间后缓存失效。也就是浏览器发出请求之前,会检查这个时间是否失效,若失效,则浏览器会重新发出请求。

开启apache expires_mod之后,浏览器在第一次将资源请求之后会缓存。

屏幕快照 2019-04-06 下午3.49.38.png

Cache-Control
Cache-Control 在 HTTP 响应头中,用于指示代理和 UA 使用何种缓存策略。比如:

  • no-cache 为本次响应不可直接用于后续请求(在没有向服务器进行校验的情况下)
  • no-store 为禁止缓存(不得存储到非易失性介质,如果有的话尽量移除,用于敏感信息)
  • public为大家都可以缓存。
  • private为仅 UA 可缓存
  • cache-control中设置max-age 为最长的缓存时间。在该时间内则使用缓存。

    屏幕快照 2019-04-06 下午4.12.30.png

    设置为no-cache之后则不会再进行缓存。
    屏幕快照 2019-04-06 下午4.17.44.png

    题外话

    在使用apache对浏览器缓存进行测试过程中发现。在不设置 cache-control的情况下,浏览器会根据自身的情况去取舍相关的缓存,可以从这查看。如果大家在服务器配置过程中发现,自己没有配置任何的缓存信息但是浏览器却缓存了资源就不用惊讶。

    【相关推荐:JavaScript视频教程】

    热心网友 时间:2022-05-14 12:45

    浏览器缓存(Browser Caching)是为了节约网络的资源加速浏览,浏览器在用户磁盘上对最近请求过的文档进行存储,当访问者再次请求这个页面时,浏览器就可以从本地磁盘显示文档,这样就可以加速页面的阅览。浏览器缓存主要有两类:缓存协商:Last-modified ,Etag 和彻底缓存:cache-control,Expires。

    声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
    饮食禁忌:哪些人群吃粽子易发病? 四类人绝不能吃粽子 家长在实施金钱激励时应该要注意哪些细节问题? 绢豆腐和内酯豆腐哪个好呢? 水分活度测定仪原理/怎么校正 湖州新旭美笔业有限公司怎么样? 深圳市新旭能科技有限公司怎么样? 北京新旭帅商贸有限公司怎么样? 苏州新旭光实业有限公司怎么样? 浙江新旭阀业有限公司怎么样? 蒸蟹子需要多长时间 系统提示 d3dx9_39.dll 丢失……导致游戏玩不了。该怎么办呢? 螃蟹蒸多长时间 螃蟹蒸多久可以吃 计算机中丢失d3dx9_39.dll 是什么意思? 怎样解决? 蒸蟹子需要多少分钟 水电图纸中vv_39是什么电线 螃蟹蒸多久就熟了 WINDOWS错误代码 39什么意思 蟹子多久能蒸熟 39和49是质数还是合数 [-39]反=__(用16位表示) 这么做的 喝蜂蜜柚子茶对身体好吗? 蜂蜜柚子茶很流行,这款保健茶饮对养生有什么效果? 蜂蜜柚子茶对身体好呢 蜂蜜柚子茶喝了对身体好吗? 论文中的英语查重吗? 我想在网上申请农业银行ETC该怎么操作? 英文摘要查重么? 中文论文 与英文论文之间可以查重吗 英文论文查重用哪个查重网站比较合适啊? 外接键盘无法识别 代码39 蟹子蒸多长时间可以吃 错误(39): 为某支持库命令提供了过多的参数。 电脑其它都正常,浏览器很卡,经常卡顿未响应 螃蟹在锅里蒸多久才可以吃啊 39<囗<58 IE浏览器反应迟缓怎么办 相对原子质量是39的元素符号 螃蟹蒸几分钟就熟了 如何调整浏览器缓存 d3dx9_39.dll缺失了,怎么办? 打开网页,出现网页错误详细信息 求解决,谢了! 39的最小因数和最大因数分别是1和13.___(判断对错) (急)五行缺什么,取名字有什么建议! 估算39×5时,可以把39看作___,估算的结果是__ 怎么删除ie8浏览器援缓 d3dx9 39.dll放在哪 帮忙取个名字 缺火 ie浏览器打开首页老缓冲怎么办 196÷39试商时,可以把39看作___,初商4偏___了,改商___.