Comet 反Ajax: 基于jQuery与PHP实现Ajax长轮询(LongPoll)

栏目: PHP · 发布时间: 6年前

内容简介:Comet 反Ajax: 基于jQuery与PHP实现Ajax长轮询(LongPoll)

传统的AJAX轮询方式,客服端以用户定义的时间间隔去服务器上查询最新的数据。种这种拉取数据的方式需要很短的时间间隔才能保证数据的精确度,但太短的时间间隔客服端会对服务器在短时间内发送出多个请求。

反转AJAX,就是所谓的长轮询或者COMET。服务器与客服端需要保持一条长时间的请求,它使得服务器在有数据时可以返回消息给客户端。

Comet是一种服务器向页面推送数据的技术,Comet能让信息近乎实时的被推送到页面上。

前端 index.html

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>jQuery与 PHP 实现Ajax长轮询</title>
    <script src="http://sources.ikeepstudying.com/js/jquery-1.11.3.min.js"></script>
    <script type="text/javascript">
        $(function(){   
            $("#btn").bind("click",{btn:$("#btn")},function(evdata){      
                 $.ajax({      
                        type:"POST",      
                        dataType:"json",      
                        url:"comet.php",      
                        timeout:10000,     //ajax请求超时时间10秒      
                        data:{time:"6"}, //3秒后无论结果服务器都返回数据      
                        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>
</head>
<body>
    <div id="msg"></div>     
    <input id="btn" type="button" value="测试" />    
</body>
</html>
<?php
 
if(empty($_POST['time'])) exit();      
set_time_limit(0);//无限请求超时时间      
$i=0;      
while (true)
{      
    //sleep(1);      
    usleep(500000);//0.5秒      
    $i++;      
          
    //若得到数据则马上返回数据给客服端,并结束本次请求      
    $rand=rand(1,999);      
    if($rand<=100){      
        $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();      
    }      
}

相关

https://segmentfault.com/a/1190000005032921


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

链接

链接

[美]艾伯特-拉斯洛•巴拉巴西 (Albert-László Barabási) / 沈华伟 / 浙江人民出版社 / 2013-8-1 / 59.90元

[内容简介] ★《链接》是《爆发》的作者,艾伯特-拉斯洛•巴拉巴西的成名之作,同时也是复杂网络的奠基之作,社交网络的入门之作。巴拉巴西之前,随机网络理论一直主导者我们的网络思维,是巴拉巴西第一个证明了,我们不是生活在随机世界里,真实网络是无尺度的。 ★巴拉巴西在书中追溯了网络的数学起源,分析了社会学家在此基础上得出的研究成果,最后提出自己的观点:我们周围的复杂网络,从鸡尾酒会、恐怖组织......一起来看看 《链接》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

SHA 加密
SHA 加密

SHA 加密工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具