關於ajax的IE cache 問題分析及解決

來源:互聯網
上載者:User

最近做了一個ajax相關的功能,大概目標根據使用者的不同登陸狀態來產生不同的歡迎語,如下:

使用者登陸了,就顯示:您好呀,又來啦!

使用者不登陸,則顯示:您還沒登陸!

 

很簡單的應用,結果我寫完ajax後,發現一個致命的問題:

Firefox中一切正常,但在IE第一次開啟沒問題,再重新整理一次,中文就會成為亂碼!

 

我仔細檢查了一下,沒結果,後來經過 Laruence 大哥的協助,才發現是IE緩衝的問題。

OK,這個問題是這個樣子的:

 

原理:

Firefox 每次 request 都會重新再回一次 server 取得最新的資料,但是 IE 就不一樣了,它會 cache
住之前得到的資料,只有第一次 request 時會真正的去 server 讀取資料,導致ajax資料不會隨時間而更新….

我開啟IE的快取檔案夾,果然發現了一個以ajax請求地址命名的檔案,開啟一看,就明白為什麼會亂碼了,因為檔案的儲存是用ANSI的。可能IE不會用GBK的編碼格式去讀取這個檔案,而會使用Unicode

 

解決方案(從網上收集的):

  1在服務端加 header("Cache-Control: no-cache, must-revalidate"); 或者用下面的組合更好一些:

 

header("Expires: Sat, 1 Jan 2005 00:00:00 GMT");
header("Last-Modified: ".gmdate( "D, d M Y H:i:s")."GMT");
header("cache-Control: no-cache, must-revalidate");
header("Pragma: no-cache"); 

 

 

  2在ajax發送請求前加上 xmlHttpRequest.setRequestHeader("If-Modified-Since","0");

  3在ajax發送請求前加上 xmlHttpRequest.setRequestHeader("Cache-Control","no-cache");

  4在 Ajax 的 URL 參數後加上 "?fresh=" + Math.random(); //當然這裡參數 fresh 可以任意取了

  5第四種方法和第三種類似,在 URL 參數後加上 "?timestamp=" + new Date().getTime(); //推薦使用這種方式,我用的就是這種,個人認為比較方便。

  6用POST替代GET:不推薦

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.