浏览器缓存

 

浏览器缓存

 

浏览器缓存是通过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字符串,是标识资源的状态。它由服务端产生来判断文件是否有更新。

 

参考资料: