浏览器缓存
Posted lulin1
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了浏览器缓存相关的知识,希望对你有一定的参考价值。
浏览器缓存
浏览器缓存
浏览器缓存是通过html的头文件中的meta来控制。http-equiv
是一个专门针对http的头文件,可以向浏览器传回一些有用的信息。与之对应的content,是各个参数的变量值。
HTTP 1.0
在HTTP1.0中通过Pragma控制页面缓存,可以设置为Pragma或no-cache。在不让浏览器或中间缓存服务器缓存页面的情况下,通常设置的值为no-cache,不过这个值不这么保险,通常还加上Expires置为0来达到目的。Expires可以用于设定网页的到期时间。一旦网页过期,必须到服务器上重新传输获取新的页面信息。PS:内容必须使用GMT的时间格式。
<meta http-equiv="Pragma" content="no-cache">
<meta http-equiv="Expires" content="0">
HTTP 1.1
在HTTP1.1中通过Cache-Control控制页面缓存,可以设置为no-cache、private、no-store、max-age或must-revalidate等,默认为private。
<meta http-equiv="Cache-Control" content="no-cache">
- public 浏览器和缓存服务器都可以缓存页面信息
- private 对于单个用户的整个或部分响应消息,不能被共享缓存处理。这允许服务器仅仅描述当用户的部分响应消息,此响应消息对于其他用户的请求无效
- no-cache 浏览器和缓存服务器都不应该缓存页面信息
- no-store 请求和响应的信息都不应该被存储在对方的磁盘系统中,不使用缓存
- must-revalidate 对于客户机的每次请求,代理服务器必须想服务器验证缓存是否过时
- max-age 客户机可以接收生存期不大于指定时间(以秒为单位)的响应
- min-fresh 客户机可以接收响应时间小于当前时间加上指定时间的响应
Last-Modified和Etags
Last-Modified服务器端文件响应头,描述最后修改时间。当浏览器再次进行请求时,会向服务器传送If-Modified-Since报头,询问时间点之后资源是否被修改过,从而区分200和304的请求状态码,304则选择浏览器缓存。
Etags不同的是,ETag是根据实体内容生成一段hash字符串,是标识资源的状态。它由服务端产生来判断文件是否有更新。
参考资料:
以上是关于浏览器缓存的主要内容,如果未能解决你的问题,请参考以下文章
Android获取各个应用程序的缓存文件代码小片段(使用AIDL)