传统的AJAX轮询形式,客服端以用户界说的工夫距离去效劳器上查问最新的数据。种这类拉取数据的形式需求很短的工夫距离能力保障数据的准确度,但过短的工夫距离客服端会对效劳器正在短期内发送出多个申请。
反转AJAX,就是所谓的长轮询或许COMET。效劳器与客服端需求放弃一条长期的申请,它使患上效劳器正在无数据时能够前往音讯给客户端。
吹完水进入正题:
这里应用AJAX申请data.php页面取得‘success’的值,申请的工夫达到80秒。正在这80秒中若不从效劳端前往‘success’则不断放弃衔接状态,直到无数据前往或‘success’的值为0才封闭衔接。正在封闭衔接后正在持续下一次的申请。
index.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"> <head> <meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> <script type="text/javascript" src="http://s1.hqbcdn.com/??lib/jquery/jquery-1.7.2.min.js"></script> </head> <body> <p id="msg"></p> <input id="btn" type="button" value="测试" /> <script type="text/javascript" > $(function(){ $("#btn").bind("click",{btn:$("#btn")},function(evdata){ $.ajax({ type:"POST", dataType:"json", url:"data.php", timeout:80000, //ajax申请超不时间80秒 data:{time:"40"}, //40秒后无论后果效劳器都前往数据 success:function(data,textStatus){ //从效劳器失去数据,显示数据并持续查问 if(data.success=="1"){ $("#msg").append("<br>[无数据]"+data.text); evdata.data.btn.click(); } //未从效劳器失去数据,持续查问 if(data.success=="0"){ $("#msg").append("<br>[有数据]"); evdata.data.btn.click(); } }, //Ajax申请超时,持续查问 error:function(XMLHttpRequest,textStatus,errorThrown){ if(textStatus=="timeout"){ $("#msg").append("<br>[超时]"); evdata.data.btn.click(); } } }); }); }); </script> </body> </html>
正在这里是有限的轮回,轮回的完结前提就是猎取到了前往后果前往Json数据。
而且承受$_POST['time']参数来限度轮回的超不时间,防止资本的适度糜费。(阅读器封闭没有会发音讯给效劳器,应用可能不断轮回上来)
data.php
<?php if(empty($_POST['time']))exit(); set_time_limit(0);//有限申请超不时间 $i=0; while (true){ sleep(1); //提早一秒 $i++; //若失去数据则即刻前往数据给客服端,并完结本次申请 $rand=rand(1,999); if($rand<=15){ $arr=array('status'=>"1",'name'=>'success','text'=>$rand); echo json_encode($arr); exit(); } //到指定超不时间还未前往数据则断开衔接 if($i==$_POST['time']){ $arr=array('status'=>"0",'name'=>'error','text'=>'有数据'); echo json_encode($arr); exit(); } } ?>
更多相干技巧文章,请拜访PHP中文网!
以上就是PHP完成长轮询【代码示例】的具体内容,更多请存眷资源魔其它相干文章!
标签: php开发教程 php开发资料 php开发自学 php轮询
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
抱歉,评论功能暂时关闭!