页面缓存参数

参考:http://xingba.iteye.com/blog/294165

 

HTTP协议中关于缓存的信息头关键字包括Cache-Control(HTTP1.1),Pragma(HTTP1.0),last-Modified,Expires等。

 

      HTTP1.0中通过Pragma 控制页面缓存,可以设置:Pragma或no-cache。网上有非常多的文章说明如何控制不让浏览器或中间缓存服务器缓存页面,通常设置的值为no- cache,不过这个值不这么保险,通常还加上Expires置为0来达到目的。但是如我们刻意需要浏览器或缓存服务器缓存住我们的页面这个值则要设置为 Pragma。

 

      HTTP1.1中启用Cache-Control 来控制页面的缓存与否,这里介绍几个常用的参数:

  • no-cache,浏览器和缓存服务器都不应该缓存页面信息;
  • public,浏览器和缓存服务器都可以缓存页面信息;
  • no-store,请求和响应的信息都不应该被存储在对方的磁盘系统中;
  • must-revalidate,对于客户机的每次请求,代理服务器必须想服务器验证缓存是否过时;
  • max-age=xxx,s-max-age=xxx,替代Expires,表示应该在xxx秒后认为页面过时,后者指示代理服务器中缓存(通常称为共享缓存)的页面过期时间。(不过我试了好多次,这个选项一直没法实现,希望有人能补充!)

       通常我们不需要缓存页面时设置该值为"no-cache,no-store,must-revalidate"(分三行代码设置);需要缓存页面信息时则设置该值为"public,max-age,s-max-age"。

 

       Last-Modified只页面的最后生成时间,GMT格式;

       Expires过时期限值,GMT格式,指浏览器或缓存服务器在该时间点后必须从真正的服务器中获取新的页面信息;

       上面两个值在JSP中设置值为字符型的GMT格式,无法生效,设置long类型才生效;

 

       最后来看一下JSP或Servlet中如何设置缓存控制信息的代码:

Java代码
       //本页面允许在浏览器端或缓存服务器中缓存,时限为10秒。
       java.util.Date date = new java.util.Date();
       response.setDateHeader("Last-Modified",date.getTime());
       response.setDateHeader("Expires",date.getTime()+10000);
    
       response.setHeader("Cache-Control", "public");
       response.setHeader("Pragma", "Pragma");
     
    Java代码
    1. //不允许浏览器端或缓存服务器缓存当前页面信息。   
    2. response.setHeader( "Pragma" "no-cache"  );  
    3. response.setDateHeader("Expires" 0 );  
    4.   
    5. response.addHeader( "Cache-Control" "no-cache"  );  
    6. response.addHeader( "Cache-Control" "no-store"  );  
    7. response.addHeader( "Cache-Control" "must-revalidate"  ); 

    你可能感兴趣的:(jsp,cache,浏览器,servlet,Blog)