亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

jquery與php結合實現AJAX長輪詢(LongPoll)

 更新時間:2015年10月12日 11:14:32   投稿:mrr  
傳統(tǒng)的AJAX輪詢方式,客服端以用戶定義的時間間隔去服務器上查詢最新的數據。種這種拉取數據的方式需要很短的時間間隔才能保證數據的精確度,但太短的時間間隔客服端會對服務器在短時間內發(fā)送出多個請求。

HTTP是無狀態(tài)、單向的協議,用戶只能夠通過客服端向服務器發(fā)送請求并由服務器處理發(fā)回一個響應。若要實現聊天室、WEBQQ、在線客服、郵箱等這些即時通訊的應用,就要用到“ 服務器推送技術(Comet)”。

傳統(tǒng)的AJAX輪詢方式,客服端以用戶定義的時間間隔去服務器上查詢最新的數據。種這種拉取數據的方式需要很短的時間間隔才能保證數據的精確度,但太短的時間間隔客服端會對服務器在短時間內發(fā)送出多個請求。

反轉AJAX,就是所謂的長輪詢或者COMET。服務器與客服端需要保持一條長時間的請求,它使得服務器在有數據時可以返回消息給客戶端。

XHTML

<div id="msg"></div>  
<input id="btn" type="button" value="測試" /> 

jQuery

這里使用AJAX請求data.php頁面獲得‘success'的值,請求的時間達到80秒。在這80秒中若沒有從服務端返回‘success'則一直保持連接狀態(tài),直到有數據返回或‘success'的值為0才關閉連接。在關閉連接后在繼續(xù)下一次的請求。

$(function(){ 
 $("#btn").bind("click",{btn:$("#btn")},function(evdata){  
   $.ajax({  
    type:"POST",  
    dataType:"json",  
    url:"data.php",  
    timeout:80000,  //ajax請求超時時間80秒  
    data:{time:"80"}, //40秒后無論結果服務器都返回數據  
    success:function(data,textStatus){  
     //從服務器得到數據,顯示數據并繼續(xù)查詢  
     if(data.success=="1"){  
      $("#msg").append("<br>[有數據]"+data.text);  
      evdata.data.btn.click();  
     }  
     //未從服務器得到數據,繼續(xù)查詢  
     if(data.success=="0"){  
     $("#msg").append("<br>[無數據]");  
     evdata.data.btn.click();  
     }  
    },  
    //Ajax請求超時,繼續(xù)查詢  
    error:function(XMLHttpRequest,textStatus,errorThrown){  
      if(textStatus=="timeout"){  
       $("#msg").append("<br>[超時]");  
       evdata.data.btn.click();  
      }  
    }  
   });  
 });  
}); 

PHP

在這里是無限的循環(huán),循環(huán)的結束條件就是獲取到了返回結果返回Json數據。

并且接受$_POST['time']參數來限制循環(huán)的超時時間,避免資源的過度浪費。(瀏覽器關閉不會發(fā)消息給服務器,使用可能一直循環(huán)下去)

if(emptyempty($_POST['time']))exit();  
set_time_limit(0);//無限請求超時時間  
$i=0;  
while (true){  
 //sleep(1);  
 usleep(500000);//0.5秒  
 $i++;  
 //若得到數據則馬上返回數據給客服端,并結束本次請求  
 $rand=rand(1,999);  
 if($rand<=15){  
  $arr=array('success'=>"1",'name'=>'xiaocai','text'=>$rand);  
  echo json_encode($arr);  
  exit();  
 }  
 //服務器($_POST['time']*0.5)秒后告訴客服端無數據  
 if($i==$_POST['time']){  
  $arr=array('success'=>"0",'name'=>'xiaocai','text'=>$rand);  
  echo json_encode($arr);  
  exit();  
 }  
} 

運行效果:在圖中可以看到無數據的請求時間達到了40S,在40S的請求中若獲得數據則請求關閉。


相關文章

  • 快速解決ajax返回值給外部函數的問題

    快速解決ajax返回值給外部函數的問題

    今天小編就為大家分享一篇快速解決ajax返回值給外部函數的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • Ajax刪除數據與查看數據操作

    Ajax刪除數據與查看數據操作

    這篇文章主要介紹了Ajax刪除數據與查看數據操作,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-03-03
  • IIS7中Ajax.AjaxMethod無效的原因及解決方法

    IIS7中Ajax.AjaxMethod無效的原因及解決方法

    使用Ajax.AjaxMethod方法在asp.net的服務器下一切正常,用iis的時候,js中總是cs類找不到,具體的解決方法如下,遇到類似情況的朋友可以參考下
    2013-07-07
  • Ajax方式實現定期更新頁面某塊內容的方法

    Ajax方式實現定期更新頁面某塊內容的方法

    這篇文章主要介紹了Ajax方式實現定期更新頁面某塊內容的方法,涉及jquery中l(wèi)oad方法Ajax調用及setInterval定時執(zhí)行的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07
  • ztree+ajax實現文件樹下載功能

    ztree+ajax實現文件樹下載功能

    這篇文章主要為大家詳細介紹了ztree+ajax實現文件樹下載功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • ajax獲取php頁面的返回參數,控件賦值的方法

    ajax獲取php頁面的返回參數,控件賦值的方法

    下面小編就為大家?guī)硪黄猘jax獲取php頁面的返回參數,控件賦值的方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • Ajax通訊原理XMLHttpRequest

    Ajax通訊原理XMLHttpRequest

    AJAX = 異步 JavaScript 和 XML。JavaScript不用說腳本語言,XML也不用說可擴展標記語言用于存放數據信息
    2011-12-12
  • react axios 跨域訪問一個或多個域名問題

    react axios 跨域訪問一個或多個域名問題

    這篇文章主要介紹了react axios 跨域訪問一個或多個域名問題,本文通過實例代碼截圖的形式給大家展示的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • 關于Ajax的疑難雜癥詳解

    關于Ajax的疑難雜癥詳解

    這篇文章主要給大家介紹了關于Ajax的疑難雜癥,文中通過實例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2022-03-03
  • Ajax遍歷jSon后對每一條數據進行相應的修改和刪除(代碼分享)

    Ajax遍歷jSon后對每一條數據進行相應的修改和刪除(代碼分享)

    這篇文章主要介紹了Ajax遍歷jSon后對每一條數據進行相應的修改和刪除的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-11-11

最新評論