HTML的HTTP协议头信息中控制着页面在几个地方的缓存信息,包括浏览器端,中间缓存服务器端(如:squid等),Web服务器端。本文讨论头信息 中带缓存控制信息的HTML页面(JSP/Servlet生成好出来的也是HTML页面)在中间缓存服务器中的缓存情况。
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,对于客户机的每次请求,代理服务器必须想服务器验证缓存是否过时;
Last-Modified只页面的最后生成时间,GMT格式;
Expires过时期限值,GMT格式,指浏览器或缓存服务器在该时间点后必须从真正的服务器中获取新的页面信息;
上面两个值在JSP中设置值为字符型的GMT格式,无法生效,设置long类型才生效;
下面是一个测试例子:
package com.servlet;import java.io.IOException;import java.io.PrintWriter;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;public class ServletA extends HttpServlet {@Overridepublic void service(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {response.setContentType( text/html //servlet页面默认是不缓存的//本页面允许在浏览器端或缓存服务器中缓存,时限为秒。//秒之内重新进入该页面的话不会进入该servlet的java.util.Date date = new java.util.Date(); response.setDateHeader( Last-Modified ,date.getTime()); //Last-Modified:页面的最后生成时间 response.setDateHeader( Expires ,date.getTime()+); //Expires:过时期限值 response.setHeader( Cache-Control , public //Cache-Control来控制页面的缓存与否,public:浏览器和缓存服务器都可以缓存页面信息;response.setHeader( Pragma , Pragma //Pragma:设置页面是否缓存,为Pragma则缓存,no-cache则不缓存//不允许浏览器端或缓存服务器缓存当前页面信息。/*response.setHeader( Pragma , no-cache ); response.setDateHeader( Expires , ); response.addHeader( Cache-Control , no-cache );//浏览器和缓存服务器都不应该缓存页面信息response.addHeader( Cache-Control , no-store );//请求和响应的信息都不应该被存储在对方的磁盘系统中; response.addHeader( Cache-Control , must-revalidate );*///于客户机的每次请求,代理服务器必须想服务器验证缓存是否过时;System.out.println( 进入了servlet response.getWriter().write( 欢迎光临我的主页 }
如果需要在html页面上设置不缓存,这在 head 标签中加入如下语句:
meta http-equiv= pragma content= no-cache meta http-equiv= cache-control content= no-cache meta http-equiv= expires content=
附:html页面中meta的作用
meta是用来在HTML文档中模拟HTTP协议的响应头报文。meta 标签用于网页的 head 与 /head 中,meta 标签的用处很多。meta 的属性有两种:name和http-equiv。name属性主要用于描述网页,对应于content(网页内容),以便于搜索引擎机器人查找、分类(目前几乎所有的搜索引擎都使用网上机器人自动查找meta值来给网页分类)。这其中最重要的是description(站点在搜索引擎上的描述)和keywords(分类关键词),所以应该给每页加一个meta值。比较常用的有以下几个:
name 属性
1、 meta name= Generator contect= 用以说明生成工具(如Microsoft FrontPage 4.0)等;
2、 meta name= KEYWords contect= 向搜索引擎说明你的网页的关键词;
3、 meta name= DEscription contect= 告诉搜索引擎你的站点的主要内容;
4、 meta name= Author contect= 你的姓名 告诉搜索引擎你的站点的制作的作者;
5、 meta name= Robots contect= all|none|index|noindex|follow|nofollow
其中的属性说明如下:
设定为all:文件将被检索,且页面上的链接可以被查询;
设定为none:文件将不被检索,且页面上的链接不可以被查询;
郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。
新闻热点
疑难解答