客户端缓存和服务器缓存处理

来源:互联网 发布:勇者之塔精灵进阶数据 编辑:程序博客网 时间:2024/05/20 11:47

问题?客户端缓存和服务器缓存处理

一、概述 

    缓存的思想可以应用在软件分层的各个层面。它是一种内部机制,对外界而言,是不可感知的。 
    数据库本身有缓存,持久层也可以缓存。(比如:hibernate,还分1级和2级缓存) 
    业务层也可以有缓存(但一般来说,这是一个过程域,不会设缓存)。 

    表现层/数据服务层(传统web的表现层)也可以设置缓存(jsp cache 就是这一层,实现在app server上的缓存机     制) 另外Browser也有缓存(如IE)这个大家也都知道(实现在 web server 上的缓存机制)。越上层的缓存效果越好,越底层的缓存影响越深远。


        

二、缓存的实现

(一)、服务端方法: 
 
<%   
response.setHeader("Pragma","No-cache");    
response.setHeader("Cache-Control","no-cache");    
response.setDateHeader("Expires", -10);   
%> 

(二)、客户端方法: 
 
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:文件将不被检索,且页面上的链接不可以被查询; 
设定为index:文件将被检索; 
设定为follow:页面上的链接可以被查询; 
设定为noindex:文件将不被检索,但页面上的链接可以被查询; 
设定为nofollow:文件将不被检索,页面上的链接可以被查询。 
 
http-equiv属性 
1、<meta http-equiv="Content-Type" contect="text/html;charset=gb_2312-80"> 
和 <meta http-equiv="Content-Language" contect="zh-CN">用以说明主页制作所使用的文字以及语
 
言;又如英文是ISO-8859-1字符集,还有BIG5、utf-8、shift-Jis、Euc、Koi8-2等字符集; 
2、<meta http-equiv="Refresh" contect="n;url=http://yourlink">定时让网页在指定的时间n内,
 
跳转到页面http;//yourlink; 
3、<meta http-equiv="Expires" contect="Mon,12 May 2001 00:20:00 GMT">可以用于设定网页的到
 
期时间,一旦过期则必须到服务器上重新调用。需要注意的是必须使用GMT时间格式; 
4、<meta http-equiv="Pragma" contect="no-cache">是用于设定禁止浏览器从本地机的缓存中调阅
 
页面内容,设定后一旦离开网页就无法从Cache中再调出; 
5、<meta http-equiv="set-cookie" contect="Mon,12 May 2001 00:20:00 GMT">cookie设定,如果
 
网页过期,存盘的cookie将被删除。需要注意的也是必须使用GMT时间格式; 
6、<meta http-equiv="Pics-label" contect="">网页等级评定,在IE的internet选项中有一项内容
 
设置,可以防止浏览一些受限制的网站,而网站的限制级别就是通过meta属性来设置的; 
7、<meta http-equiv="windows-Target" contect="_top">强制页面在当前窗口中以独立页面显示,
 
可以防止自己的网页被别人当作一个frame页调用; 
8、<meta http-equiv="Page-Enter" contect="revealTrans(duration=10,transtion= 50)">和<
 
meta http-equiv="Page-Exit" contect="revealTrans(duration=20,transtion =6)">设定进入和离
 
开页面时的特殊效果,这个功能即FrontPage中的“格式/网页过渡”,不过所加的页面不能够是一个
 
frame页面。 


三、缓存应用 
 
(一)、防止JSP页面缓存为了防止浏览器缓存当前访问的JSP动态页面,可以采用如下的方式进行设置

<% 
// 将过期日期设置为一个过去时间 
 
response.setHeader("Expires", "Sat, 6 May 1995 12:00:00 GMT"); 
 
// 设置 HTTP/1.1 no-cache 头 
response.setHeader("Cache-Control", "no-store,no-cache,must-revalidate"); 
 
// 设置 IE 扩展 HTTP/1.1 no-cache headers, 用户自己添加 
response.addHeader("Cache-Control", "post-check=0, pre-check=0"); 
 
// 设置标准 HTTP/1.0 no-cache header. 
response.setHeader("Pragma", "no-cache"); 
%> 
 
当然,每一个页面都包含这些代码会很繁琐,可以通过自定义过滤器(Filter)的方法来处理相关的页
 
面 。



二、缓存实现(浏览器缓存当前访问的JSP动态页面) 

(二)、jsp,html 清除页面缓存 
 
1.禁止客户端缓存要在<head>中加入类似如下内容: 
 
<META HTTP-EQUIV="pragma" CONTENT="no-cache"> 
<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate"> 
<META HTTP-EQUIV="expires" CONTENT="Wed, 26 Feb 1997 08:21:57 GMT"> 
 
或   <meta http-equiv="pragma" content="no-cache"> 
     <meta http-equiv="cache-control" content="no-cache"> 
     <meta http-equiv="expires" content="0">   
 
2.在服务器的动态网页中禁止缓存,要加入类似如下脚本 
 
response.setHeader("Pragma","No-cache"); 
response.setHeader("Cache-Control","no-cache"); 
response.setDateHeader("Expires", 0);  
 
(三)设置有限时间的缓存 
 
    int minutes = 10; 
    Date d = new Date(); 
    String modDate = d.toGMTString(); 
    String expDate = null; 
    expDate = (new Date(d.getTime() + minutes * 60000)).toGMTString(); 
    response.setHeader("Last-Modified", modDate); 
    response.setHeader("Expires", expDate); 
    response.setHeader("Cache-Control", "public"); //   HTTP/1.1 
    response.setHeader("Pragma", "Pragma"); //   HTTP/1.0  
 
补充:关于.jsp cache的几条建议: 
1.jsp cache最好做在过滤器上,把需要缓冲的页面集中在同一个目录下,每次更改只须更改web.xml就可
以完成缓冲设置,这样比较方便. 
2.Gzip压缩可以将页面压缩得很小,平均压缩比为1/3,jsp cache的HashMap缓冲压缩后的页面,肯定比没
压缩前更节约内存消耗,并且效率更高.关于Gzip可以参考这个开源项
目:http://sourceforge.net/projects/pjl-comp-filter  

其他缓存设置:

1.禁止客户端缓存要在
<head>中加入类似如下内容
<META HTTP-EQUIV="pragma" CONTENT="no-cache"> 
<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate"> 
<META HTTP-EQUIV="expires" CONTENT="Wed, 26 Feb 1997 08:21:57 GMT">
 
2.在服务器的动态网页中禁止缓存,要加入类似如下脚本
 
(1)asp
<% 
Response.Expires = -1 
Response.ExpiresAbsolute = Now() - 1 
Response.cachecontrol = "no-cache" 
%>
 
(2)php
header("Pragma:no-cache");  
header("Cache-Control","no-cache"); 
header("Expires:0");
 
(3)jsp
response.setHeader("Pragma","No-cache"); 
response.setHeader("Cache-Control","no-cache"); 
response.setDateHeader("Expires", 0);


******网页头部信息的说明:*******

1.Pragma HTTP头信息 (为什么它不起作用)

     这是请求型头信息 Pragma属性(头信息也由浏览器发送给服务器),虽然少数集中缓存服务器会遵循这个头信息,但大部分不会,所以Pragma也不起什么作用。要用就使 用下列头信息如Expires(过期时间),属性是HTTP控制缓存的基本手段,这个属性告诉缓存器:相关副本在多长时间内是新鲜的。


2.**几乎所有的缓存服务器都支持Expires(过期时间)属性

   expires头部信息对于静态图片的缓存来说,特别有用,你可以给它们设置一个特别长的过期时间,这会使你的网站对用户变得相应非常快。也可以设置一个过期时间,过了时间后这样缓存服务器就知道什么时候去取一个更新版本了。记住:HTTP的日期时间必须是格林威治时间(GMT),而不是本地时间

(要求:Web服务器的时间和缓存服务器的时间必须是同步的)。

举例:
Expires: Fri, 30 Oct 1998 14:19:41 GMT


3.Cache-Control(缓存控制) HTTP头信息

1介绍了另外一组头信息属性:Cache-Control响应头信息,让网站的发布者可以更全面的控制他们的内容,并定位过期时间的限制。有用的 Cache-Control响应头信息包括:max-age=[秒] — 执行缓存被认为是最新的最长时间。类似于过期时间,这个参数是基于请求时间的相对时间间隔,而不是绝对过期时间,[秒]是一个数字,单位是秒:从请求时间开始到过期时间之间的秒数。s-maxage=[秒] — 类似于max-age属性,除了他应用于共享(如:代理服务器)缓存public — 标记认证内容也可以被缓存,一般来说: 经过HTTP认证才能访问的内容,输出是自动不可以
缓存的;no-cache — 强制每次请求直接发送给源服务器而不经过本地缓存版本的校验。这对于需要确认认证
应用很有用(可以和public结合使用),或者严格要求使用最新数据的应用(不惜牺牲使用缓存的所有好处);
no-store — 强制缓存在任何情况下都不要保留任何副本must-revalidate — 告诉缓存必须遵循所有你给予副本的新鲜度的,HTTP允许缓存在某些特定情况下返回过期数据,指定了这个属性,你高速缓存,你希望严格的遵循你的规则。proxy-revalidate — 和 must-revalidate类似,除了他只对缓存代理服务器起作用
举例:
Cache-Control: max-age=3600, must-revalidate


0 0
原创粉丝点击