溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

jquery與php結(jié)合如何實(shí)現(xiàn)AJAX長(zhǎng)輪詢(xún)

發(fā)布時(shí)間:2021-09-02 11:02:45 來(lái)源:億速云 閱讀:114 作者:小新 欄目:web開(kāi)發(fā)

這篇文章主要介紹了jquery與php結(jié)合如何實(shí)現(xiàn)AJAX長(zhǎng)輪詢(xún),具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

HTTP是無(wú)狀態(tài)、單向的協(xié)議,用戶(hù)只能夠通過(guò)客服端向服務(wù)器發(fā)送請(qǐng)求并由服務(wù)器處理發(fā)回一個(gè)響應(yīng)。若要實(shí)現(xiàn)聊天室、WEBQQ、在線客服、郵箱等這些即時(shí)通訊的應(yīng)用,就要用到“ 服務(wù)器推送技術(shù)(Comet)”。

傳統(tǒng)的AJAX輪詢(xún)方式,客服端以用戶(hù)定義的時(shí)間間隔去服務(wù)器上查詢(xún)最新的數(shù)據(jù)。種這種拉取數(shù)據(jù)的方式需要很短的時(shí)間間隔才能保證數(shù)據(jù)的精確度,但太短的時(shí)間間隔客服端會(huì)對(duì)服務(wù)器在短時(shí)間內(nèi)發(fā)送出多個(gè)請(qǐng)求。

反轉(zhuǎn)AJAX,就是所謂的長(zhǎng)輪詢(xún)或者COMET。服務(wù)器與客服端需要保持一條長(zhǎng)時(shí)間的請(qǐng)求,它使得服務(wù)器在有數(shù)據(jù)時(shí)可以返回消息給客戶(hù)端。

XHTML

<div id="msg"></div>  
<input id="btn" type="button" value="測(cè)試" />

jQuery

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

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

PHP

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

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

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

運(yùn)行效果:在圖中可以看到無(wú)數(shù)據(jù)的請(qǐng)求時(shí)間達(dá)到了40S,在40S的請(qǐng)求中若獲得數(shù)據(jù)則請(qǐng)求關(guān)閉。

jquery與php結(jié)合如何實(shí)現(xiàn)AJAX長(zhǎng)輪詢(xún)

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“jquery與php結(jié)合如何實(shí)現(xiàn)AJAX長(zhǎng)輪詢(xún)”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI