强制缓存和协商缓存的区别

1.强制缓存和协商缓存主要是针对静态资源进行缓存的。

2.强制缓存是当浏览器向服务器发请求时,资源未过期,服务器直接返还缓存资源,过期重新发请求。
3.协商缓存是浏览器向服务器发请求时先发一次get请求,问服务器缓存资源有更新吗,没有则命中缓存,有则重新发请求。
4.cache- control的参数有,no-cache,开启协商缓存,no-store是不开启缓存。public是否进行代理服务器缓存,用户信息等私人信息建议不开启,private是不开启代理服务器缓存。max-age缓存过期时间,s-maxage代理服务器缓存过期时间。
5.强制缓存可以有两种设置方式,expires和cache-control:max-age=5单位是秒,第一种依赖本地时间戳,第二种是第一种的替代方案,除非要向下兼容时用第一种。强制缓存可能更新不及时
6.协商缓存要先将cache- control设置为no-cache,开启协商缓存。然后也有两种设置方式,last-modified和etag,第一种弊端是内容没有发生改变,只是资源名称变了都会重新请求,第二种生成etag指纹,内容发生变化都会生成新的,当生成etag的资源过大时,更新比较频繁会造成开销,所以二者要根据资源的特性合理选择那种模式。
7.图片和css文件可以用强制缓存,图片不会常更新内容,css文件打包时文件名是hash拼接的,每次更新文件名都不一样,所以可以当作请求路径,每次更新也能保证缓存资源是最新的

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
强制缓存协商缓存是两种不同的缓存机制,它们在处理缓存请求时有一些区别强制缓存是通过在响应头中设置`Cache-Control`或`Expires`字段,告诉浏览器在一段时间内直接使用缓存的资源,而不需要发送请求到服务器。当浏览器再次请求相同资源时,会先检查本地缓存是否过期,如果没有过期,则直接使用缓存的资源。这样可以减少网络请求,提高页面加载速度。但是,如果服务器端资源发生了更新,浏览器无法立即获取最新的版本。 协商缓存则是通过在响应头中设置`ETag`或`Last-Modified`字段,告诉浏览器如何验证缓存的资源是否有效。当浏览器再次请求相同资源时,会发送一个条件请求到服务器,包含`If-None-Match`(对应`ETag`)或`If-Modified-Since`(对应`Last-Modified`)字段,服务器根据这些字段判断资源是否更新。如果资源没有更新,则返回一个空的响应,告诉浏览器可以使用缓存的资源。如果资源已经更新,则服务器会返回新的资源。这样可以避免了每次都下载完整的资源,减少了网络传输的数据量。 区别总结: - 强制缓存是根据时间或过期规则,直接使用缓存资源,不与服务器通信;协商缓存是通过与服务器通信,根据资源的验证信息来判断是否使用缓存。 - 强制缓存不需要发送请求到服务器,适用于静态资源,可以提高页面加载速度;协商缓存需要发送条件请求到服务器,适用于动态资源,可以减少数据传输量。 - 强制缓存无法立即获取最新版本的资源;协商缓存可以及时获取到最新资源。 综合来说,强制缓存适用于不经常变动的静态资源,而协商缓存适用于经常变动的动态资源。通常情况下,可以同时使用强制缓存协商缓存来优化缓存策略。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值