佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > JSP頁(yè)面緩存cache技術(shù)--瀏覽器緩存介紹及實(shí)現(xiàn)方法

JSP頁(yè)面緩存cache技術(shù)--瀏覽器緩存介紹及實(shí)現(xiàn)方法

熱門(mén)標(biāo)簽:電子圍欄 銀行業(yè)務(wù) Linux服務(wù)器 服務(wù)器配置 Mysql連接數(shù)設(shè)置 阿里云 團(tuán)購(gòu)網(wǎng)站 科大訊飛語(yǔ)音識(shí)別系統(tǒng)
一、概述
緩存的思想可以應(yīng)用在軟件分層的各個(gè)層面。它是一種內(nèi)部機(jī)制,對(duì)外界而言,是不可感知的。
數(shù)據(jù)庫(kù)本身有緩存,持久層也可以緩存。(比如:hibernate,還分1級(jí)和2級(jí)緩存)
業(yè)務(wù)層也可以有緩存(但一般來(lái)說(shuō),這是一個(gè)過(guò)程域,不會(huì)設(shè)緩存)。
表現(xiàn)層/數(shù)據(jù)服務(wù)層(傳統(tǒng)web的表現(xiàn)層)也可以設(shè)置緩存(jsp cache 就是這一層,實(shí)現(xiàn)在app server上的緩存機(jī)制)
另外Browser也有緩存(如IE)這個(gè)大家也都知道(實(shí)現(xiàn)在 web server 上的緩存機(jī)制)。越上層的緩存效果越好,越底層的緩存影響越深遠(yuǎn)。

二、緩存實(shí)現(xiàn)(瀏覽器緩存當(dāng)前訪問(wèn)的JSP動(dòng)態(tài)頁(yè)面)
(一)、服務(wù)端方法
復(fù)制代碼 代碼如下:


response.setHeader("Pragma","No-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expires", -10);
%>

(二)、客戶(hù)端方法
meta是用來(lái)在HTML文檔中模擬HTTP協(xié)議的響應(yīng)頭報(bào)文。meta 標(biāo)簽用于網(wǎng)頁(yè)的<head>與</head>中,meta 標(biāo)簽的用處很多。meta 的屬性有兩種:name和http-equiv。name屬性主要用于描述網(wǎng)頁(yè),對(duì)應(yīng)于content(網(wǎng)頁(yè)內(nèi)容),以便于搜索引擎機(jī)器人查找、分類(lèi)(目前幾乎所有的搜索引擎都使用網(wǎng)上機(jī)器人自動(dòng)查找meta值來(lái)給網(wǎng)頁(yè)分類(lèi))。這其中最重要的是description(站點(diǎn)在搜索引擎上的描述)和keywords(分類(lèi)關(guān)鍵詞),所以應(yīng)該給每頁(yè)加一個(gè)meta值。比較常用的有以下幾個(gè):
name 屬性
1、<meta name="Generator" contect="">用以說(shuō)明生成工具(如Microsoft FrontPage 4.0)等;
2、<meta name="KEYWords" contect="">向搜索引擎說(shuō)明你的網(wǎng)頁(yè)的關(guān)鍵詞;
3、<meta name="DEscription" contect="">告訴搜索引擎你的站點(diǎn)的主要內(nèi)容;
4、<meta name="Author" contect="你的姓名">告訴搜索引擎你的站點(diǎn)的制作的作者;
5、<meta name="Robots" contect="all|none|index|noindex|follow|nofollow">
其中的屬性說(shuō)明如下
設(shè)定為all:文件將被檢索,且頁(yè)面上的鏈接可以被查詢(xún);
設(shè)定為none:文件將不被檢索,且頁(yè)面上的鏈接不可以被查詢(xún);
設(shè)定為index:文件將被檢索;
設(shè)定為follow:頁(yè)面上的鏈接可以被查詢(xún);
設(shè)定為noindex:文件將不被檢索,但頁(yè)面上的鏈接可以被查詢(xún);
設(shè)定為nofollow:文件將不被檢索,頁(yè)面上的鏈接可以被查詢(xún)。
http-equiv屬性
1、<meta http-equiv="Content-Type" contect="text/html";charset=gb_2312-80">
和<meta http-equiv="Content-Language" contect="zh-CN">用以說(shuō)明主頁(yè)制作所使用的文字以及語(yǔ)言;又如英文是ISO-8859-1字符集,還有BIG5、utf-8、shift-Jis、Euc、Koi8-2等字符集;
2、<meta http-equiv="Refresh" contect="n;url=http://yourlink">定時(shí)讓網(wǎng)頁(yè)在指定的時(shí)間n內(nèi),跳轉(zhuǎn)到頁(yè)面http;//yourlink;
3、<meta http-equiv="Expires" contect="Mon,12 May 2001 00:20:00 GMT">可以用于設(shè)定網(wǎng)頁(yè)的到期時(shí)間,一旦過(guò)期則必須到服務(wù)器上重新調(diào)用。需要注意的是必須使用GMT時(shí)間格式;
4、<meta http-equiv="Pragma" contect="no-cache">是用于設(shè)定禁止瀏覽器從本地機(jī)的緩存中調(diào)閱頁(yè)面內(nèi)容,設(shè)定后一旦離開(kāi)網(wǎng)頁(yè)就無(wú)法從Cache中再調(diào)出;
5、<meta http-equiv="set-cookie" contect="Mon,12 May 2001 00:20:00 GMT">cookie設(shè)定,如果網(wǎng)頁(yè)過(guò)期,存盤(pán)的cookie將被刪除。需要注意的也是必須使用GMT時(shí)間格式;
6、<meta http-equiv="Pics-label" contect="">網(wǎng)頁(yè)等級(jí)評(píng)定,在IE的internet選項(xiàng)中有一項(xiàng)內(nèi)容設(shè)置,可以防止瀏覽一些受限制的網(wǎng)站,而網(wǎng)站的限制級(jí)別就是通過(guò)meta屬性來(lái)設(shè)置的;
7、<meta http-equiv="windows-Target" contect="_top">強(qiáng)制頁(yè)面在當(dāng)前窗口中以獨(dú)立頁(yè)面顯示,可以防止自己的網(wǎng)頁(yè)被別人當(dāng)作一個(gè)frame頁(yè)調(diào)用;
8、<meta http-equiv="Page-Enter" contect="revealTrans(duration=10,transtion= 50)">和<meta http-equiv="Page-Exit" contect="revealTrans(duration=20,transtion =6)">設(shè)定進(jìn)入和離開(kāi)頁(yè)面時(shí)的特殊效果,這個(gè)功能即FrontPage中的“格式/網(wǎng)頁(yè)過(guò)渡”,不過(guò)所加的頁(yè)面不能夠是一個(gè)frame頁(yè)面。
三、緩存應(yīng)用
(一)、防止JSP頁(yè)面緩存為了防止瀏覽器緩存當(dāng)前訪問(wèn)的JSP動(dòng)態(tài)頁(yè)面,可以采用如下的方式進(jìn)行設(shè)置:
%
// 將過(guò)期日期設(shè)置為一個(gè)過(guò)去時(shí)間
response.setHeader("Expires", "Sat, 6 May 199512:00:00 GMT");
// 設(shè)置 HTTP/1.1 no-cache 頭
response.setHeader("Cache-Control", "no-store,no-cache,must-revalidate");
// 設(shè)置 IE 擴(kuò)展 HTTP/1.1 no-cache headers, 用戶(hù)自己添加
response.addHeader("Cache-Control", "post-check=0, pre-check=0");
// 設(shè)置標(biāo)準(zhǔn) HTTP/1.0 no-cache header.
response.setHeader("Pragma", "no-cache");
%>
當(dāng)然,每一個(gè)頁(yè)面都包含這些代碼會(huì)很繁瑣,可以通過(guò)自定義過(guò)濾器(Filter)的方法來(lái)處理相關(guān)的頁(yè)面
(二)、jsp,html 清除頁(yè)面緩存
1.禁止客戶(hù)端緩存要在head>中加入類(lèi)似如下內(nèi)容:
復(fù)制代碼 代碼如下:

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 199708:21:57 GMT">


復(fù)制代碼 代碼如下:

meta http-equiv="pragma" content="no-cache">
meta http-equiv="cache-control" content="no-cache">
meta http-equiv="expires" content="0">

2.在服務(wù)器的動(dòng)態(tài)網(wǎng)頁(yè)中禁止緩存,要加入類(lèi)似如下腳本
復(fù)制代碼 代碼如下:

response.setHeader("Pragma","No-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expires", 0);

(三)設(shè)置有限時(shí)間的緩存
復(fù)制代碼 代碼如下:

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

補(bǔ)充:關(guān)于.jsp cache的幾條建議:
1.jsp cache最好做在過(guò)濾器上,把需要緩沖的頁(yè)面集中在同一個(gè)目錄下,每次更改只須更改web.xml就可以完成緩沖設(shè)置,這樣比較方便.
2.Gzip壓縮可以將頁(yè)面壓縮得很小,平均壓縮比為1/3,jsp cache的HashMap緩沖壓縮后的頁(yè)面,肯定比沒(méi)壓縮前更節(jié)約內(nèi)存消耗,并且效率更高.
您可能感興趣的文章:
  • JS localStorage實(shí)現(xiàn)本地緩存的方法
  • 讓html頁(yè)面不緩存js的實(shí)現(xiàn)方法
  • JS清除IE瀏覽器緩存的方法
  • 高性能WEB開(kāi)發(fā) JS、CSS的合并、壓縮、緩存管理
  • 禁止js文件緩存的代碼
  • js 設(shè)置緩存及獲取設(shè)置的緩存
  • js、css、img等瀏覽器緩存問(wèn)題的2種解決方案
  • Js 代碼中,ajax請(qǐng)求地址后加隨機(jī)數(shù)防止瀏覽器緩存的原因
  • 詳解AngularJS中$http緩存以及處理多個(gè)$http請(qǐng)求的方法
  • JS實(shí)現(xiàn)前端緩存的方法

標(biāo)簽:江蘇 廣元 大理 蚌埠 衢州 萍鄉(xiāng) 衡水 棗莊

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《JSP頁(yè)面緩存cache技術(shù)--瀏覽器緩存介紹及實(shí)現(xiàn)方法》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢(xún)

    • 400-1100-266
    阿合奇县| 安阳县| 丰都县| 南宫市| 鲜城| 日土县| 武义县| 休宁县| 洛隆县| 象州县| 郯城县| 正安县| 南川市| 田东县| 墨脱县| 榕江县| 绥阳县| 鹤岗市| 荥阳市| 黔西县| 镇康县| 西畴县| 乌兰县| 磐安县| 耒阳市| 宜黄县| 菏泽市| 景谷| 崇仁县| 禹州市| 宣武区| 贺州市| 玉山县| 广州市| 麻栗坡县| 正定县| 同仁县| 辽宁省| 中卫市| 昌平区| 安岳县|