作者:飞儿gxj_505 | 来源:互联网 | 2023-09-16 02:16
问题?客户端缓存和服务器缓存处理
一、概述
缓存的思想可以应用在软件分层的各个层面。它是一种内部机制,对外界而言,是不可感知的。
数据库本身有缓存,持久层也可以缓存。(比如:hibernate,还分1级和2级缓存)
业务层也可以有缓存(但一般来说,这是一个过程域,不会设缓存)。
表现层/数据服务层(传统web的表现层)也可以设置缓存(jsp cache 就是这一层,实现在app server上的缓存机 制) 另外Browser也有缓存(如IE)这个大家也都知道(实现在 web server 上的缓存机制)。越上层的缓存效果越好,越底层的缓存影响越深远。
二、缓存的实现
(一)、服务端方法:
<&#xff05;
response.setHeader("Pragma","No-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expires", -10);
&#xff05;>
&#xff08;二&#xff09;、客户端方法&#xff1a;
meta是用来在HTML文档中模拟HTTP协议的响应头报文。meta 标签用于网页的&#xff1c;head&#xff1e;与&#xff1c;/head&#xff1e;中&#xff0c;
meta 标签的用处很多。meta 的属性有两种&#xff1a;name和http-equiv。name属性主要用于描述网页&#xff0c;对应于
content&#xff08;网页内容&#xff09;&#xff0c;以便于搜索引擎机器人查找、分类&#xff08;目前几乎所有的搜索引擎都使用网上机器人
自动查找meta值来给网页分类&#xff09;。这其中最重要的是description&#xff08;站点在搜索引擎上的描述&#xff09;和
keywords&#xff08;分类关键词&#xff09;&#xff0c;所以应该给每页加一个meta值。比较常用的有以下几个&#xff1a;
name 属性
1、&#xff1c;meta name&#61;"Generator" contect&#61;""&#xff1e;用以说明生成工具&#xff08;如Microsoft FrontPage 4.0&#xff09;等&#xff1b;
2、&#xff1c;meta name&#61;"KEYWords" contect&#61;""&#xff1e;向搜索引擎说明你的网页的关键词&#xff1b;
3、&#xff1c;meta name&#61;"DEscription" contect&#61;""&#xff1e;告诉搜索引擎你的站点的主要内容&#xff1b;
4、&#xff1c;meta name&#61;"Author" contect&#61;"你的姓名"&#xff1e;告诉搜索引擎你的站点的制作的作者&#xff1b;
5、&#xff1c;meta name&#61;"Robots" contect&#61;"all|none|index|noindex|follow|nofollow"&#xff1e;
其中的属性说明如下&#xff1a;
设定为all&#xff1a;文件将被检索&#xff0c;且页面上的链接可以被查询&#xff1b;
设定为none&#xff1a;文件将不被检索&#xff0c;且页面上的链接不可以被查询&#xff1b;
设定为index&#xff1a;文件将被检索&#xff1b;
设定为follow&#xff1a;页面上的链接可以被查询&#xff1b;
设定为noindex&#xff1a;文件将不被检索&#xff0c;但页面上的链接可以被查询&#xff1b;
设定为nofollow&#xff1a;文件将不被检索&#xff0c;页面上的链接可以被查询。
http-equiv属性
1、&#xff1c;meta http-equiv&#61;"Content-Type" contect&#61;"text/html;charset&#61;gb_2312-80"&#xff1e;
和 &#xff1c;meta http-equiv&#61;"Content-Language" contect&#61;"zh-CN"&#xff1e;用以说明主页制作所使用的文字以及语
言&#xff1b;又如英文是ISO-8859-1字符集&#xff0c;还有BIG5、utf-8、shift-Jis、Euc、Koi8-2等字符集&#xff1b;
2、&#xff1c;meta http-equiv&#61;"Refresh" contect&#61;"n;url&#61;http://yourlink"&#xff1e;定时让网页在指定的时间n内&#xff0c;
跳转到页面http;//yourlink&#xff1b;
3、&#xff1c;meta http-equiv&#61;"Expires" contect&#61;"Mon,12 May 2001 00:20:00 GMT"&#xff1e;可以用于设定网页的到
期时间&#xff0c;一旦过期则必须到服务器上重新调用。需要注意的是必须使用GMT时间格式&#xff1b;
4、&#xff1c;meta http-equiv&#61;"Pragma" contect&#61;"no-cache"&#xff1e;是用于设定禁止浏览器从本地机的缓存中调阅
页面内容&#xff0c;设定后一旦离开网页就无法从Cache中再调出&#xff1b;
5、&#xff1c;meta http-equiv&#61;"set-COOKIE" contect&#61;"Mon,12 May 2001 00:20:00 GMT"&#xff1e;COOKIE设定&#xff0c;如果
网页过期&#xff0c;存盘的COOKIE将被删除。需要注意的也是必须使用GMT时间格式&#xff1b;
6、&#xff1c;meta http-equiv&#61;"Pics-label" contect&#61;""&#xff1e;网页等级评定&#xff0c;在IE的internet选项中有一项内容
设置&#xff0c;可以防止浏览一些受限制的网站&#xff0c;而网站的限制级别就是通过meta属性来设置的&#xff1b;
7、&#xff1c;meta http-equiv&#61;"windows-Target" contect&#61;"_top"&#xff1e;强制页面在当前窗口中以独立页面显示&#xff0c;
可以防止自己的网页被别人当作一个frame页调用&#xff1b;
8、&#xff1c;meta http-equiv&#61;"Page-Enter" contect&#61;"revealTrans(duration&#61;10,transtion&#61; 50)"&#xff1e;和&#xff1c;
meta http-equiv&#61;"Page-Exit" contect&#61;"revealTrans(duration&#61;20&#xff0c;transtion &#61;6)"&#xff1e;设定进入和离
开页面时的特殊效果&#xff0c;这个功能即FrontPage中的“格式/网页过渡”&#xff0c;不过所加的页面不能够是一个
frame页面。
三、缓存应用
&#xff08;一&#xff09;、防止JSP页面缓存为了防止浏览器缓存当前访问的JSP动态页面&#xff0c;可以采用如下的方式进行设置
<%
// 将过期日期设置为一个过去时间
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&#xff0c; 用户自己添加
response.addHeader("Cache-Control", "post-check&#61;0, pre-check&#61;0");
// 设置标准 HTTP/1.0 no-cache header.
response.setHeader("Pragma", "no-cache");
%>
当然&#xff0c;每一个页面都包含这些代码会很繁琐&#xff0c;可以通过自定义过滤器&#xff08;Filter&#xff09;的方法来处理相关的页
面 。
二、缓存实现&#xff08;浏览器缓存当前访问的JSP动态页面&#xff09;
&#xff08;二&#xff09;、jsp,html 清除页面缓存
1.禁止客户端缓存要在中加入类似如下内容&#xff1a;
或
2.在服务器的动态网页中禁止缓存&#xff0c;要加入类似如下脚本
response.setHeader("Pragma","No-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expires", 0);
&#xff08;三&#xff09;设置有限时间的缓存
int minutes &#61; 10;
Date d &#61; new Date();
String modDate &#61; d.toGMTString();
String expDate &#61; null;
expDate &#61; (new Date(d.getTime() &#43; 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
补充&#xff1a;关于.jsp cache的几条建议:
1.jsp cache最好做在过滤器上,把需要缓冲的页面集中在同一个目录下,每次更改只须更改web.xml就可
以完成缓冲设置,这样比较方便.
2.Gzip压缩可以将页面压缩得很小,平均压缩比为1/3,jsp cache的HashMap缓冲压缩后的页面,肯定比没
压缩前更节约内存消耗,并且效率更高.关于Gzip可以参考这个开源项
目:http://sourceforge.net/projects/pjl-comp-filter
其他缓存设置&#xff1a;
1.禁止客户端缓存要在
中加入类似如下内容
2.在服务器的动态网页中禁止缓存&#xff0c;要加入类似如下脚本
(1)asp
<%
Response.Expires &#61; -1
Response.ExpiresAbsolute &#61; Now() - 1
Response.cachecontrol &#61; "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属性&#xff08;头信息也由浏览器发送给服务器&#xff09;&#xff0c;虽然少数集中缓存服务器会遵循这个头信息&#xff0c;但大部分不会&#xff0c;所以Pragma也不起什么作用。要用就使 用下列头信息如Expires&#xff08;过期时间&#xff09;&#xff0c;属性是HTTP控制缓存的基本手段&#xff0c;这个属性告诉缓存器&#xff1a;相关副本在多长时间内是新鲜的。
2.**几乎所有的缓存服务器都支持Expires&#xff08;过期时间&#xff09;属性
expires头部信息对于静态图片的缓存来说&#xff0c;特别有用&#xff0c;你可以给它们设置一个特别长的过期时间&#xff0c;这会使你的网站对用户变得相应非常快。也可以设置一个过期时间&#xff0c;过了时间后这样缓存服务器就知道什么时候去取一个更新版本了。记住&#xff1a;HTTP的日期时间必须是格林威治时间&#xff08;GMT&#xff09;&#xff0c;而不是本地时间
(要求:Web服务器的时间和缓存服务器的时间必须是同步的)。
举例&#xff1a;
Expires: Fri, 30 Oct 1998 14:19:41 GMT
3.Cache-Control&#xff08;缓存控制&#xff09; HTTP头信息
1介绍了另外一组头信息属性&#xff1a;Cache-Control响应头信息&#xff0c;让网站的发布者可以更全面的控制他们的内容&#xff0c;并定位过期时间的限制。有用的 Cache-Control响应头信息包括&#xff1a;max-age&#61;[秒] — 执行缓存被认为是最新的最长时间。类似于过期时间&#xff0c;这个参数是基于请求时间的相对时间间隔&#xff0c;而不是绝对过期时间&#xff0c;[秒]是一个数字&#xff0c;单位是秒&#xff1a;从请求时间开始到过期时间之间的秒数。s-maxage&#61;[秒] — 类似于max-age属性&#xff0c;除了他应用于共享&#xff08;如&#xff1a;代理服务器&#xff09;缓存public — 标记认证内容也可以被缓存&#xff0c;一般来说&#xff1a; 经过HTTP认证才能访问的内容&#xff0c;输出是自动不可以
缓存的&#xff1b;no-cache — 强制每次请求直接发送给源服务器&#xff0c;而不经过本地缓存版本的校验。这对于需要确认认证
应用很有用&#xff08;可以和public结合使用&#xff09;&#xff0c;或者严格要求使用最新数据的应用&#xff08;不惜牺牲使用缓存的所有好处&#xff09;&#xff1b;
no-store — 强制缓存在任何情况下都不要保留任何副本must-revalidate — 告诉缓存必须遵循所有你给予副本的新鲜度的&#xff0c;HTTP允许缓存在某些特定情况下返回过期数据&#xff0c;指定了这个属性&#xff0c;你高速缓存&#xff0c;你希望严格的遵循你的规则。proxy-revalidate — 和 must-revalidate类似&#xff0c;除了他只对缓存代理服务器起作用
举例:
Cache-Control: max-age&#61;3600, must-revalidate