Expires和Cache-Control的理解

最近在学Nginx,学到有个地方式设置响应头信息,其中有两项是设置Expires和Cache-Control,来设置缓存时间,后来发现"并没有什么卵用",于是就搜了下资料,把整个思路理顺了。

由于是讲讲Expires和Cache-Control这两个响应头的作用,所以具体怎么添加就不展开,每种语言都有自己的做法,而我刚好在学Nginx,所以就使用Nginx来添加响应头了。

首先,先将浏览器的缓存给清掉,然后浏览一个静态网页(包含一个js和一张图片),请求头和响应头如下:


请求了这3个问题,浏览器会进行缓存,然后刷新页面,会看到全部是304状态

这里主要If-Modifed-Since和Cache-Control

304状态代表请求的这个文件在服务器中没有变化,具体过程如下:

在第一次请求的时候,服务器会返回Last-Modified字段,后来的请求中,浏览器会把值放在If-Modifed-Since请求头中发送给服务器进行比对,如果文件修改了,那么就返回最新的文件,即200状态;如果没有修改,那么返回304状态,且max-age<=0

再次清空浏览器缓存,然后给响应头加上Expires,时间为1天,然后刷新页面,查看

看下Expires,值是过期的时间。Cache-Control:max-age=86400,表示缓存1天

再次刷新页面,发现居然是304状态,还是想服务器发送请求了

当时这觉得好像和预想的不一样,这种情况下应该没有请求发送才对,因为设置了expires缓存1天

后来查了下资料,发现不用刷新页面了,再刷新还是304,应该是在地址栏按回车。。。。

查到的资料说,地址栏刷新和F5刷新不一样,F5刷新是一定会发送请求的,好吧,那我就按地址栏了。。。。


果然成功了,Transferred显示cached,表示从缓存中取文件,而不是向服务器请求

ps:这里有个问题是这里显示了2条请求记录,有的浏览器是3条(我这里用的是火狐,谷歌是3条)

也就是说,缓存在地址栏回车的时候才有效,另外通过超链接过去的也是有效的,而F5是会发生请求的


然后可以设置一下Expires的值,设置小一点,10s,10s后再地址栏按回车查看,会重新发送请求,Expires的缓存时间设置是成功的


最后,再简单说下Cache-Control的另外一个值,no-store。

如果响应头带有Cache-Control:no-store,那么浏览器每次发生请求都是200,而不会是304

可以自己去试下,这种情况下,浏览器不会保存缓存文件

,


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Cache-Control是HTTP报文头部的一个字段,它用来控制浏览器或者服务器的缓存策略,而Expires是Cache-Control的一个参数,它指定缓存的过期时间。因此,Expires和Cache-Control之间存在密切的关系。 ### 回答2: Expires和Cache-Control是HTTP响应头中用于控制缓存策略的两个重要字段。 Expires字段指定了服务器响应的内容过期的时间,以GMT格式的日期和时间表示。客户端在接收到响应后,会将该时间保存下来。当客户端再次请求该资源时,会将请求中的If-Modified-Since字段的值设置为之前保存的Expires值。服务器会根据该字段的值判断资源是否过期,如果没有过期,则返回304 Not Modified状态码,通知客户端使用本地缓存。 Cache-Control字段则更加灵活,它用于定义缓存的各种行为和策略。常用的指令有: - public:表示该响应可以被任何缓存保存,包括公共缓存和私有缓存。 - private:表示该响应只能被私有缓存保存,不能被共享缓存或代理服务器缓存。 - no-cache:表示缓存不能直接使用已有的响应,需要向服务器进行验证后才能使用。 - max-age:用于指定响应的有效时间,以秒为单位。如max-age=3600表示该响应在接下来的一个小时内有效。 当同时存在Expires和Cache-Control字段时,Cache-Control的优先级更高。如果Cache-Control字段中定义了max-age指令,则Expires字段会被忽略。因此,Cache-Control可以更灵活地控制缓存过期时间,而不依赖于具体的日期和时间。 综上所述,Expires和Cache-Control都是用于控制缓存的字段,但Cache-Control的控制更加灵活,并且具有更高的优先级。在实际应用中,一般推荐使用Cache-Control来定义缓存策略。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值