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

一、概述

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

客户端缓存和服务器缓存处理相关推荐

  1. 本地缓存、服务器缓存、分布式缓存介绍

    缓存的意义 缓存存在的意义: 1.减轻数据库压力 2.提升接口的性能 3.缓解服务器压力(不用每次去请求资源): 4.提升性能(打开本地资源速度当然比请求回来再打开要快得多): 5.减少带宽消耗 例如 ...

  2. 浏览器缓存和服务器缓存

    1.浏览器缓存就是当你打开一个网页,浏览器会自动下载副本到你电脑上,就相当于你另存为网页到某个地方而已,只不过这里是自动而已.当然不是浏览器能把各种 网页都能下载到本地电脑上,它是有特殊情况.一般ht ...

  3. java服务器缓存_Java服务器缓存溢出有哪些呢、?

    在C程序中,缓存溢出是最常见的安全隐患.缓存溢出在用户输入超过已分配内存空间(专供用户输入使用)时出现.缓存溢出可能成为导致应用被覆盖的关键因素.C程序很容易出现缓存溢出,但Java程序几乎不可能出现 ...

  4. 改善服务器响应用时,服务器缓存论文,关于改善网络服务器响应速度建议相关参考文献资料-免费论文范文...

    导读:本论文是一篇免费优秀的关于服务器缓存论文范文资料,可用于相关论文写作参考. 摘 要:目前 ,应网络为平台的信息应用是普遍存在的,不论是园区网内的信息应用,还是 internet 之上的信息应用, ...

  5. JS缓存与浏览器缓存技术详解 学习笔记

    缓存与浏览器缓存技术: 一,缓存: 缓存是网络传输中常用到的一种技术,利用缓存可以让我们在数据传输方面更加的方便和快捷. 1.1缓存的优点: 避免冗余的数据传输: 当很多的人去访问一个网站的原始服务器 ...

  6. 缓存(CDN缓存,浏览器(客户端)缓存)

    1.什么是缓存? 缓存是一种数据结构,用于快速查找以及执行的操作结果.因此,如果一个操作执行起来很慢,对于常用的输入数据就可以将操作的结果缓存,并在下次调用该操作时使用缓存的数据. 缓存是一个到处都存 ...

  7. 缓存nginx服务器的静态文件

    ------26--张立-- 目的: 缓存nginx服务器的静态文件.如css,js,htm,html,jpg,gif,png,flv,swf,这些文件都不是经常更新.便于缓存以减轻服务器的压力. 实 ...

  8. Redis缓存数据库服务器

    Redis缓存数据库服务器 Redis是一个开源的科技与内存也可持久化的日志型.Key-Value数据库 Redis的存储分为内存存储.磁盘存储和Log文件三部分,配置文件中有三个参数对其进行配置. ...

  9. redis 缓存数据_Redis 缓存数据方案对比:常规 VS 高并发服务器

    1 Redis 是什么 Redis 是一种开源的非关系型数据库.起源于负载较大时,当前关系型数据库无法承载的情况. 到目前为止,Redis 可以用作数据库.缓存.消息处理.Redis 可以存储键和5种 ...

最新文章

  1. tftp下载内核和文件系统
  2. pythonweb扫描器_Python安全工具之web目录扫描
  3. 用vim看代码的常用指令
  4. what happens if PR_TYPE is mapped to a given transaction type
  5. 客户机操作系统已禁用 cpu。请关闭或重置虚拟机。_黑科技教学丨Win10竟然内置了一台虚拟机?教你如何玩转它...
  6. java ioc_Java体验IOC
  7. 官方实锤!程序员都是农民工?
  8. fruncm server sql 无法生成 线程_SQL Server无法生成FRunCM线程的解决方法
  9. C++ 3D物理引擎库BulletPhysics基本使用
  10. 获取和使用某些网站的iconfont图标字体
  11. Listary 高效启动器(win)
  12. 大规模电机控制的方案选择-电机和驱动器篇
  13. android 特效调节app,美化AndroidApp的常用特效
  14. 清华陈丹琦:如何让「大模型」变小
  15. Au入门系列之七:效果器
  16. ES6 模板字符串方法
  17. SQL 排序时对Null值的处理
  18. 学计算机的大学计划书,计算机系大学计划书
  19. 他,被骗了5万块钱,大家一定擦亮双眼,只要涉及转账的,就一定是骗子,没有万一
  20. 适合三本计算机专业考研的学校,适合三本考研的学校有哪些

热门文章

  1. android 模拟器作用,安卓模拟器:看似简单实则用处极大的日常功能
  2. 赣州有哪些计算机高职学校,2018赣州专科学校有哪些最新高职院校名单
  3. 2017年3月13号课堂笔记
  4. 从零开始构建一个个人网站
  5. 关于分压电阻的大小对交流波形的分析
  6. Express全系列教程之(四):获取Post参数的两种方式
  7. groovy匕首方法
  8. Hadoop作业调度
  9. Linux Mint 19.1 配置开发环境记录【含:输入法安装、字体模糊解决等问题】
  10. java 将应用程序打成可执行的JAR包,然后使用批处理方式运行