HTTP缓存机制

本文介绍了HTTP缓存的两种机制:强缓存和协商缓存。强缓存通过Expires和Cache-Control头控制,协商缓存则依赖Last-Modified和ETag进行资源验证,以减少不必要的网络请求并提高性能。
摘要由CSDN通过智能技术生成

HTTP缓存可分为强缓存和协商缓存

1.强缓存

    强缓存的实现可以通过设置两种HTTP Header实现,分别是Expires和CacheControl。强缓存表示在缓存期间不需要请求,返回的HTTP状态码为200。

    Expires是HTTP1的产物,表示资源会在设定时间后过期,之后需要再次进行请求。它受制于本地时间,假设修改了本地时间,可能会造成缓存失效。

    CatchControl是HTTP1.1出现的,他的优先级比Expire要高。它表示资源会在30秒之后过期,需要再次请求。CatchControl里面有几个字段分别代表的含义是1.no-store:在浏览器使用缓存前,会对比Etag,进行判断,如果没变,则返回304,使用缓存2.no-catch:禁用缓冲,所有内容都不会被缓存活或者缓存到临时文件中3.max-age:内容缓存将在设定时间内失效,可在HTTP1.1使用,与last-modified一起使用优先级更高

2.协商缓存

    如果缓存过期了,就要去发起请求,验证资源是否更新,协商缓存可以通过设置两种HTTP Header实现,分别是Last-Modified和ETag。当浏览器发起请求验证资源时,如果资源没有做改变,那么服务端就会返回304状态码,并且更新浏览器缓存的有效期

    Last-Modified表示本地文件最后修改日期,if-Modified-Since会将Last-Modifi

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值