HTTP头的Expires与Cache-control

转自:http://blog.csdn.net/kozazyh/archive/2009/07/19/4361977.aspx

1.概念

Cache-control 用于控制HTTP缓存(在HTTP/1.0中可能部分没实现,仅仅实现了Pragma: no-cache)

数据包中的格式:

Cache-Control: cache-directive

cache-directive可以为以下:

request时用到:

| "no-cache"


| "no-store"


| "max-age" "=" delta-seconds


| "max-stale" [ "=" delta-seconds ]


| "min-fresh" "=" delta-seconds


| "no-transform"


| "only-if-cached"


| "cache-extension"


response时用到:

| "public"


| "private" [ "=" <"> field-name <"> ]


| "no-cache" [ "=" <"> field-name <"> ]


| "no-store"


| "no-transform"


| "must-revalidate"


| "proxy-revalidate"


| "max-age" "=" delta-seconds


| "s-maxage" "=" delta-seconds


| "cache-extension"


部分说明:


根据是否可缓存分为


Public  指示响应可被任何缓存区缓存。


Private  指示对于单个用户的整个或部分响应消息,不能被共享缓存处理。这允许服务器仅仅描述当用户的


部分响应消息,此响应消息对于其他用户的请求无效。


no-cache  指示请求或响应消息不能缓存(HTTP/1.0用Pragma的no-cache替换)


根据什么能被缓存


no-store  用于防止重要的信息被无意的发布。在请求消息中发送将使得请求和响应消息都不使用缓存。


根据缓存超时


max-age  指示客户机可以接收生存期不大于指定时间(以秒为单位)的响应。


min-fresh  指示客户机可以接收响应时间小于当前时间加上指定时间的响应。


max-stale  指示客户机可以接收超出超时期间的响应消息。如果指定max-stale消息的值,那么客户机可以


接收超出超时期指定值之内的响应消息。


Expires

 表示存在时间,允许客户端在这个时间之前不去检查(发请求),等同max-age的


效果。但是如果同时存在,则被Cache-Control的max-age覆盖。


格式:


Expires = "Expires" ":" HTTP-date


例如


Expires: Thu, 01 Dec 1994 16:00:00 GMT (必须是GMT格式
 
2.应用


通过HTTP的META设置expires和cache-control


<meta http-equiv="Cache-Control" content="max-age=7200" />


<meta http-equiv="Expires" content="Mon, 20 Jul 2009 23:00:00 GMT" />


上述设置仅为举例,实际使用其一即可。这样写的话仅对该网页有效,对网页中的图片或其他请求无效,并不会做任何cache。


这样客户端的请求就多了,尽管只是检查Last-modified状态的东西,但是请求一多对浏览速度必定有影响。
如果要对文件添加cache可以通过apache的mod_expire模块,写法为


<IfModule mod_expires.c>


ExpiresActive On


ExpiresDefault "access plus 1 days"
</IfModule>


记得ExpiresActive设为On,我起先没设置On,似乎怎样YSlow都查不到缓存机制。这样添加的话就是默认所有的。
如果要针对个别MIME类型则可以:


ExpiresByType image/gif "access plus 5 hours 3 minutes"


见 Apache Module mod_expires

另外,当点击浏览器上的刷新,客户端发送的请求中均是max-age=0,表示validate操作,发送请求到服务器 要求检查cache,再更新cache,一般得到的是304 Not Modified,表示没变动。
 

参考:





HTTP RFC2616 HeaderField









HTTP协议基础


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值