隨筆 - 0, 文章 - 75, 評(píng)論 - 0, 引用 - 0
          數(shù)據(jù)加載中……

          Ajax緩存解決辦法

          項(xiàng)目有時(shí)要用一些Ajax的效果,因?yàn)楸容^簡(jiǎn)單,也就沒(méi)有去用什么Ajax.net之類(lèi)的東西,手寫(xiě)代碼也就實(shí)現(xiàn)了。、


          第二天,有人向我報(bào)告錯(cuò)誤;說(shuō)是只有第一次讀取的值正常,后面的值都不正常;我調(diào)試了一下,確實(shí)有這樣的問(wèn)題,查出是因?yàn)锳JAX緩存的問(wèn)題:解決辦法有如下幾種:


          1、在服務(wù)端加
          header("Cache-Control: no-cache, must-revalidate");(如php中)


            2、在ajax發(fā)送請(qǐng)求前加上
          anyAjaxObj.setRequestHeader("If-Modified-Since","0");


            3、在ajax發(fā)送請(qǐng)求前加上
          anyAjaxObj.setRequestHeader("Cache-Control","no-cache");


            4、在 Ajax 的 URL 參數(shù)后加上 "?fresh=" +
          Math.random(); //當(dāng)然這里參數(shù) fresh 可以任意取了


            5、第五種方法和第四種類(lèi)似,在 URL 參數(shù)后加上 "?timestamp=" + new
          Date().getTime();


            6、用POST替代GET:不推薦



          1、加個(gè)隨機(jī)數(shù)

          xmlHttp.open("GET", "ajax.asp?now=" + new Date().getTime(),
          true);

          2、在要異步獲取的asp頁(yè)面中寫(xiě)一段禁止緩存的代碼:

          Response.Buffer =True
          Response.ExpiresAbsolute
          =Now() - 1

          Response.Expires=0

          Response.CacheControl="no-cache"


          3、在ajax發(fā)送請(qǐng)求前加上x(chóng)mlHTTP.setRequestHeader("If-Modified-Since","0");可以禁止緩存

          xmlHTTP.open("get", URL, true);

          xmlHTTP.onreadystatechange = callHTML;

          xmlHTTP.setRequestHeader("If-Modified-Since","0");

          xmlHTTP.send();


          另一個(gè)作者寫(xiě)到:



          AJAX的緩存是由瀏覽器維持的,對(duì)于發(fā)向服務(wù)器的某個(gè)url,ajax僅在第一次請(qǐng)求時(shí)與服務(wù)器交互信息,之后的請(qǐng)求中,ajax不再向服務(wù)器提交請(qǐng)求,而是直接從緩存中提取數(shù)據(jù)。

          有些情況下,我們需要每一次都從服務(wù)器得到更新后數(shù)據(jù)。思路是讓每次請(qǐng)求的url都不同,而又不影響正常應(yīng)用:在url之后加入隨機(jī)內(nèi)容。
          e.g.
          url=url+"&"+Math.random();

          Key
          points:
          1.每次請(qǐng)求的url都不一樣(ajax的緩存便不起作用)
          2.不影響正常應(yīng)用(最基本的)

          ----------------
          方法二:(未經(jīng)證實(shí))
          在JSP中禁止緩存
          response.addHeader("Cache-Control",
          "no-cache");
          response.addHeader("Expires", "Thu, 01 Jan 1970 00:00:01
          GMT");

          HTTP:
          <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="expires" CONTENT="0">


          另一個(gè)作者寫(xiě)到:


          我們都知道,ajax能提高頁(yè)面載入的速度的主要原因是通過(guò)ajax減少了重復(fù)數(shù)據(jù)的載入,真正做到按需獲取,既然如此,我們?cè)趯?xiě)ajax程序的時(shí)候不妨送佛送到西,在客戶(hù)端再做一次緩存,進(jìn)一步提高數(shù)據(jù)載入速度。那就是在載入數(shù)據(jù)的同時(shí)將數(shù)據(jù)緩存在瀏覽器內(nèi)存中,一旦數(shù)據(jù)被載入,只要頁(yè)面未刷新,該數(shù)據(jù)就永遠(yuǎn)的緩存在內(nèi)存中,當(dāng)用戶(hù)再次查看該數(shù)據(jù)時(shí),則不需要從服務(wù)器上去獲取數(shù)據(jù),極大的降低了服務(wù)器的負(fù)載和提高了用戶(hù)的體驗(yàn)。

          posted on 2012-04-22 16:04 hantai 閱讀(54) 評(píng)論(0)  編輯  收藏


          只有注冊(cè)用戶(hù)登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 西畴县| 张家界市| 西贡区| 安化县| 都江堰市| 比如县| 德格县| 红桥区| 天祝| 连江县| 岑巩县| 潞西市| 图木舒克市| 武定县| 陆良县| 武胜县| 锦屏县| 湄潭县| 高青县| 长丰县| 财经| 台山市| 新邵县| 枝江市| 抚顺市| 洛隆县| 上栗县| 屏东市| 旬阳县| 苍梧县| 扎鲁特旗| 岳西县| 牟定县| 区。| 大丰市| 会同县| 吉木萨尔县| 兰西县| 聊城市| 安陆市| 合山市|