HTTP的缓存分为两类:
1. 按时间
Expires / Cache-Control:
expires是设置一个过期的时限,cache-control则是设置一个从当前起过期的秒数.
当这些设置生效时,浏览器不会向服务器发起request.
2. 按条件
Last-Modified / If-Modified-Since
前者是响应头,后者是请求头,服务器根据收到的请求头来比对是否需要传送数据,对于静态文件来说,一般是该文件的mtime的gmt格式.
ETag / If-None-Match
机制和Modified组一样,只是不是用时间,而且自己设tag
现在知道了,rails的Asset ID其实是配合Expires/Cache-Control使用,例如设置一个很大的值,则仅在修改assetid后,浏览器才会发出访问的请求.
而Modified组则是最普通的静态文件处理方式,好处是可以省掉很多配置.
而在实际观察firefox2.0.20,对于Modified组合,firefox似乎会设置一个时长,在这个市场之内是不会发起静态资源的请求,且对图片的时间间隔要较css js短.而在发现离请求的时间(Date字段)超出很长时间后,会向服务器发起请求,但有时会带上
If-Modified-Since 有时又会不带.