• 欢迎访问奇跡の海网站,本站不上传任何资源,所有资源均来自于网络,欢迎加入奇跡の海~!奇跡の海-WordPress QQ群
  • 本站下载资源为网络上收集整理而来,并且以计算机技术研究交流为目的,版权归原作者所有,仅供大家参考,学习,不存在任何商业目的与商业用途.
  • 本站系统镜像均来自于官方原版,ed2k可视为P2P下载链接。所有操作系统默认均为试用版,如有正版密钥可以有效激活,本站不提供任何激活和相关服务。

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

网络技术 奇跡の海 1年前 (2017-12-11) 276次浏览 已收录 0个评论 扫描二维码

一、概述
缓存的思想可以应用在软件分层的各个层面。它是一种内部机制,对外界而言,是不可感知的。
数据库本身有缓存,持久层也可以缓存。(比如: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


版权声明:本站所有文章和资源使用CC BY-NC-SA 4.0协议授权发布 , 转载应当以相同方式注明文章来自“SeaOMC.COM->客户端缓存和服务器缓存处理!在下边可以分享本文哦!
喜欢 (0)
[]
分享 (0)
奇跡の海
关于作者:
一个WordPress菜鸟!
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址