程序员需要了解的浏览器缓存技术

栏目: IT资讯 · 发布时间: 6年前

内容简介:做web开发的同学(前端工程师和后端工程师),经常遇到响应304,304的意思就是浏览器已经缓存,不需要走服务器,浏览器直接响应数据给用户,最常用的解决浏览器缓存的问题,就是在静态文件后面添加版本号,让浏览器不响应缓存。那么web浏览器是怎么缓存数据的:早起的web就是通过这个字段来告诉浏览器该缓存多久,这种缓存的原理是根据当前服务器的时间加上缓存有效的时间,最终生成未来某个失效时间值,返回给浏览器,比如失效时间点为2020 ,那么当用户刷新页面的时候,就会先判断当前时间是否到2020年,如果没到,浏览器把

做web开发的同学(前端工程师和后端工程师),经常遇到响应304,304的意思就是浏览器已经缓存,不需要走服务器,浏览器直接响应数据给用户,最常用的解决浏览器缓存的问题,就是在静态文件后面添加版本号,让浏览器不响应缓存。那么web浏览器是怎么缓存数据的:

Expires

早起的web就是通过这个字段来告诉浏览器该缓存多久,这种缓存的原理是根据当前服务器的时间加上缓存有效的时间,最终生成未来某个失效时间值,返回给浏览器,比如失效时间点为2020 ,那么当用户刷新页面的时候,就会先判断当前时间是否到2020年,如果没到,浏览器把缓存的数据直接返回给用户,不走web服务器,这种缓存的一个缺点就是:如果用户修改了自己的本地时间,那么缓存可能失效。

程序员需要了解的浏览器缓存技术

Cache-control

因为Expires的缺点,后来的cache-control就做了改进,cache-control不再存绝对时间,存的是相对时间,比如缓存是60秒,需要注意的是如果你设置了max-age=60,那么在这60秒内,即使服务端修改了,你也得不到最新的数据,所以这个使用要慎重,对应的另一个还有叫no-cache的,no-cahe并不是不缓存,而是每次都要和服务器做比较,如果服务器未更新那么就读取缓存,反之读取最新的,与no-cache对应的就是no-store。no-store才是真的告诉浏览器不要读取缓存的意思。

程序员需要了解的浏览器缓存技术

Last-Modified和If-Modified-Since

Last-Modified是服务器返回给浏览器的

If-Modified-Since是浏览器告诉服务器的

举个例子,如果你第一次访问个url,肯定没缓存走服务器,服务器返回个Last-Modified,即这个资源最近被修改的时间A,响应的http状态码是200,同时浏览器把这个时间A存起来,下次请求的时候,浏览器会带着这个If-Modified-Since去和服务器做对比,如果说,两次的时间一样,那么就是资源没更新,浏览器直接返回自己缓存的资源,响应的http状态码是304,如果说两次时间不一样,那么服务器再次返回Last-Modified时间和200的http状态码。但是这种策略也有缺点,就是时间最小单位是1s,如果说1秒内发了好几次更新,浏览器就不知道了。

程序员需要了解的浏览器缓存技术

Etag和If-no-match

由于Last-Modified不支持秒级的变化,后来出现了Etag,Etag是文件修改时间等hash的结果,不存具体时间值,这样每次请求的时候,浏览器会带上If-no-match和服务器的Etag做对比,如果一样,走缓存,不一样,走服务器,然后缓存起来,可以精确到秒级

程序员需要了解的浏览器缓存技术


以上所述就是小编给大家介绍的《程序员需要了解的浏览器缓存技术》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数学建模

数学建模

[美] Frank R.Giordano,Maurice D.Weir,William P.Fox / 机械工业出版社 / 2004-1 / 45.00元

数学建模是用数学方法解决各种实际问题的桥梁。本书分离散建模(第1~9章)和连续建模(第10~13章)两部分介绍了整个建模过程的原理,通过本书的学习,学生将**会在创造性模型和经验模型的构建、模型分析以及模型研究方面进行实践,增强解决问题的能力。 ·论证了离散动力系统,离散优化等技术对现代应用数学的发展的促进作用。 ·在创造性模型和经验模型的构建、模型分析以及模型研究中融入个人项目和小组......一起来看看 《数学建模》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试