真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何解決IE針對Ajax請求結(jié)果的緩存問題

本篇文章給大家分享的是有關(guān)如何解決IE針對Ajax請求結(jié)果的緩存問題,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

創(chuàng)新互聯(lián)主要從事成都做網(wǎng)站、網(wǎng)站設(shè)計(jì)、網(wǎng)頁設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)廣東,十載網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):18982081108

在默認(rèn)情況下,IE會針對請求地址緩存Ajax請求的結(jié)果。換句話說,在緩存過期之前,針對相同地址發(fā)起的多個Ajax請求,只有第一次會真正發(fā)送到服務(wù)端。在某些情況下,這種默認(rèn)的緩存機(jī)制并不是我們希望的(比如獲取實(shí)時數(shù)據(jù))。

一、問題重現(xiàn)。

我們通過一個ASP.NET MVC應(yīng)用來重現(xiàn)IE針對Ajax請求結(jié)果的緩存。在一個空ASP.NET MVC應(yīng)用中我們定義了如下一個默認(rèn)的HomeController,其中包含一個返回當(dāng)前時間的Action方法GetCurrentTime。

 public class HomeController Controller
 {
  public ActionResult Index()
  {
   return View();
  }
  
  public string GetCurrentTime()
  {
   return DateTime.Now.ToLongTimeString();
  }
 }

默認(rèn)Action方法Index對應(yīng)的View定義如下。我們每隔5秒鐘利用JQuery的方法以Ajax的方式調(diào)用GetCurrentTime操作,并將返回的結(jié)果顯示出來。


 
  
   @ViewBag.Title 
   
   
    $(function () {
     window.setInterval(function () {
      $.ajax({
       url'@Url.Action("GetCurrentTime")',
       success function (result) {
        $("ul").append("
  • " + result + "
  • ");        }       });      }, );     });               
          

      采用不同的瀏覽器運(yùn)行該程序會得到不同的輸出結(jié)果,如下圖所示,Chrome瀏覽器中能夠顯示出實(shí)時時間,但是在IE中顯示的時間都是相同的。

      如何解決IE針對Ajax請求結(jié)果的緩存問題

      如何解決IE針對Ajax請求結(jié)果的緩存問題

      二、通過為URL地址添加后綴的方式解決問題

      由于IE針對Ajax請求的返回的結(jié)果是根據(jù)請求地址進(jìn)行緩存的,所以如果不希望這個緩存機(jī)制生效,我們可以在每次請求時為請求地址添加不同的后綴來解決這個問題。針對這個例子,我們通過如下的代碼為請求地址添加一個基于當(dāng)前時間的查詢字符串,再次運(yùn)行程序后IE中將會顯示實(shí)時的時間。

       
       
          
         
          $(function () {
           window.setInterval(function () {
            $.ajax({
             url'@Url.Action("GetCurrentTime")?'+ new Date().toTimeString() ,
             success function (result) {
              $("ul").append("
    • " + result + "
    • ");        }       });      }, );     });         

      三、通過jQuery的Ajax設(shè)置解決問題

      實(shí)際上jQuery具有針對這個的Ajax設(shè)置,我們只需要按照如下的方式調(diào)用$.ajaxSetup方法禁止掉Ajaz的緩存機(jī)制。

       
       
          
         
          $(function () {
           $.ajaxSetup({ cache false }); 
           window.setInterval(function () {
            $.ajax({
             url'@Url.Action("GetCurrentTime")',
             success function (result) {
              $("ul").append("
    • " + result + "
    • ");        }       });      }, );     });         

      實(shí)際上jQuery的這個機(jī)制也是通過為請求地址添加不同的查詢字符串后綴來實(shí)現(xiàn)的,這可以通過Fiddler攔截的請求來證實(shí)。

      如何解決IE針對Ajax請求結(jié)果的緩存問題

      四、通過定制響應(yīng)解決問題

      我們可以通過請求的響應(yīng)來控制瀏覽器針對結(jié)果的緩存,為此我們定義了如下一個名為NoCacheAttribute的ActionFilter。在實(shí)現(xiàn)的OnActionExecuted方法中,我們調(diào)用當(dāng)前HttpResponse的SetCacheability方法將緩存選項(xiàng)設(shè)置為NoCache。該NoCacheAttribute特性被應(yīng)用到GetCurrentTime方法后,運(yùn)行我們的程序在IE中依然可以得到實(shí)時的時間。

      public class HomeController Controller
       {
        public ActionResult Index()
        {
         return View();
        }
        
        [NoCache] 
        public string GetCurrentTime()
        {
         return DateTime.Now.ToLongTimeString();
        }
       }
       public class NoCacheAttribute FilterAttribute, IActionFilter
       {
        public void OnActionExecuted(ActionExecutedContext filterContext)
        {
         filterContext.HttpContext.Response.Cache.SetCacheability(HttpCacheability.NoCache);
        }
       
        public void OnActionExecuting(ActionExecutingContext filterContext)
        {}
       }

      實(shí)際NoCacheAttribute特性最終控制消息消息的Cache-Control報(bào)頭,并將其設(shè)置為“no-cache”,指示瀏覽器不要對結(jié)果進(jìn)行緩存。如下所示的是針對GetCurrentTime請求的響應(yīng)消息:

       HTTP/. OK
       Server ASP.NET Development Server/...
       Date Thu, Jan GMT
       X-AspNet-Version ..
       X-AspNetMvc-Version .
       Cache-Control no-cache 
       Pragma no-cache
       Expires -
       Content-Type text/html; charset=utf-
       Content-Length 
       Connection Close
       PM

      以上就是如何解決IE針對Ajax請求結(jié)果的緩存問題,小編相信有部分知識點(diǎn)可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


      當(dāng)前題目:如何解決IE針對Ajax請求結(jié)果的緩存問題
      當(dāng)前鏈接:http://weahome.cn/article/peohgj.html

      其他資訊

      在線咨詢

      微信咨詢

      電話咨詢

      028-86922220(工作日)

      18980820575(7×24)

      提交需求

      返回頂部