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

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

熱門標(biāo)簽:山東ai外呼電銷機(jī)器人好用嗎 汝南縣地圖標(biāo)注app 外呼直播語音系統(tǒng) 甘肅銷售電銷機(jī)器人公司 地圖標(biāo)注專業(yè)和非專業(yè) 四川正規(guī)外呼系統(tǒng)軟件 智能電話機(jī)器人銷售話術(shù) 湖北地圖標(biāo)注公司 福建電銷貓機(jī)器人收費(fèi)
一、概述
緩存的思想可以應(yīng)用在軟件分層的各個(gè)層面。它是一種內(nèi)部機(jī)制,對外界而言,是不可感知的。
數(shù)據(jù)庫本身有緩存,持久層也可以緩存。(比如:hibernate,還分1級(jí)和2級(jí)緩存)
業(yè)務(wù)層也可以有緩存(但一般來說,這是一個(gè)過程域,不會(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)前訪問的JSP動(dòng)態(tài)頁面)
(一)、服務(wù)端方法
復(fù)制代碼 代碼如下:


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

(二)、客戶端方法
meta是用來在HTML文檔中模擬HTTP協(xié)議的響應(yīng)頭報(bào)文。meta 標(biāo)簽用于網(wǎng)頁的<head>與</head>中,meta 標(biāo)簽的用處很多。meta 的屬性有兩種:name和http-equiv。name屬性主要用于描述網(wǎng)頁,對應(yīng)于content(網(wǎng)頁內(nèi)容),以便于搜索引擎機(jī)器人查找、分類(目前幾乎所有的搜索引擎都使用網(wǎng)上機(jī)器人自動(dòng)查找meta值來給網(wǎng)頁分類)。這其中最重要的是description(站點(diǎn)在搜索引擎上的描述)和keywords(分類關(guān)鍵詞),所以應(yīng)該給每頁加一個(gè)meta值。比較常用的有以下幾個(gè):
name 屬性
1、<meta name="Generator" contect="">用以說明生成工具(如Microsoft FrontPage 4.0)等;
2、<meta name="KEYWords" contect="">向搜索引擎說明你的網(wǎng)頁的關(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">
其中的屬性說明如下
設(shè)定為all:文件將被檢索,且頁面上的鏈接可以被查詢;
設(shè)定為none:文件將不被檢索,且頁面上的鏈接不可以被查詢;
設(shè)定為index:文件將被檢索;
設(shè)定為follow:頁面上的鏈接可以被查詢;
設(shè)定為noindex:文件將不被檢索,但頁面上的鏈接可以被查詢;
設(shè)定為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">定時(shí)讓網(wǎng)頁在指定的時(shí)間n內(nèi),跳轉(zhuǎn)到頁面http;//yourlink;
3、<meta http-equiv="Expires" contect="Mon,12 May 2001 00:20:00 GMT">可以用于設(shè)定網(wǎng)頁的到期時(shí)間,一旦過期則必須到服務(wù)器上重新調(diào)用。需要注意的是必須使用GMT時(shí)間格式;
4、<meta http-equiv="Pragma" contect="no-cache">是用于設(shè)定禁止瀏覽器從本地機(jī)的緩存中調(diào)閱頁面內(nèi)容,設(shè)定后一旦離開網(wǎng)頁就無法從Cache中再調(diào)出;
5、<meta http-equiv="set-cookie" contect="Mon,12 May 2001 00:20:00 GMT">cookie設(shè)定,如果網(wǎng)頁過期,存盤的cookie將被刪除。需要注意的也是必須使用GMT時(shí)間格式;
6、<meta http-equiv="Pics-label" contect="">網(wǎng)頁等級(jí)評(píng)定,在IE的internet選項(xiàng)中有一項(xiàng)內(nèi)容設(shè)置,可以防止瀏覽一些受限制的網(wǎng)站,而網(wǎng)站的限制級(jí)別就是通過meta屬性來設(shè)置的;
7、<meta http-equiv="windows-Target" contect="_top">強(qiáng)制頁面在當(dāng)前窗口中以獨(dú)立頁面顯示,可以防止自己的網(wǎng)頁被別人當(dāng)作一個(gè)frame頁調(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)入和離開頁面時(shí)的特殊效果,這個(gè)功能即FrontPage中的“格式/網(wǎng)頁過渡”,不過所加的頁面不能夠是一個(gè)frame頁面。
三、緩存應(yīng)用
(一)、防止JSP頁面緩存為了防止瀏覽器緩存當(dāng)前訪問的JSP動(dòng)態(tài)頁面,可以采用如下的方式進(jìn)行設(shè)置:
%
// 將過期日期設(shè)置為一個(gè)過去時(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, 用戶自己添加
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è)頁面都包含這些代碼會(huì)很繁瑣,可以通過自定義過濾器(Filter)的方法來處理相關(guān)的頁面
(二)、jsp,html 清除頁面緩存
1.禁止客戶端緩存要在head>中加入類似如下內(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)頁中禁止緩存,要加入類似如下腳本
復(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最好做在過濾器上,把需要緩沖的頁面集中在同一個(gè)目錄下,每次更改只須更改web.xml就可以完成緩沖設(shè)置,這樣比較方便.
2.Gzip壓縮可以將頁面壓縮得很小,平均壓縮比為1/3,jsp cache的HashMap緩沖壓縮后的頁面,肯定比沒壓縮前更節(jié)約內(nèi)存消耗,并且效率更高.
您可能感興趣的文章:
  • JS localStorage實(shí)現(xiàn)本地緩存的方法
  • 讓html頁面不緩存js的實(shí)現(xiàn)方法
  • JS清除IE瀏覽器緩存的方法
  • 高性能WEB開發(fā) JS、CSS的合并、壓縮、緩存管理
  • 禁止js文件緩存的代碼
  • js 設(shè)置緩存及獲取設(shè)置的緩存
  • js、css、img等瀏覽器緩存問題的2種解決方案
  • Js 代碼中,ajax請求地址后加隨機(jī)數(shù)防止瀏覽器緩存的原因
  • 詳解AngularJS中$http緩存以及處理多個(gè)$http請求的方法
  • JS實(shí)現(xiàn)前端緩存的方法

標(biāo)簽:吳忠 黔東 臨沂 昌都 肇慶 南充 梅州 白銀

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《JSP頁面緩存cache技術(shù)--瀏覽器緩存介紹及實(shí)現(xiàn)方法》,本文關(guān)鍵詞  JSP,頁面,緩存,cache,技術(shù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《JSP頁面緩存cache技術(shù)--瀏覽器緩存介紹及實(shí)現(xiàn)方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于JSP頁面緩存cache技術(shù)--瀏覽器緩存介紹及實(shí)現(xiàn)方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章