php弹幕技术轮询,PHP+Ajax实现在线聊天长轮询

HTML

首先我们放置一个获取数据按钮和数据存放地方#msg。

jQuery

我们向ajax.php请求,请求的时间设置80秒。在这80秒中若没有从服务端返回‘success’则一直保持连接状态,直到有数据返回或‘success’的值为0才关闭连接。在关闭连接后在继续下一次的请求。$(function() {

$("#btn").bind("click", {

btn: $("#btn")

},

function(evdata) {

$.ajax({

type: "POST",

dataType: "json",

url: "ajax.php",

timeout: 80000,//ajax请求超时时间80秒

data: {

time: "80"

},

//40秒后无论结果服务器都返回数据

success: function(data, textStatus) {

//从服务器得到数据,显示数据并继续查询

if (data.success == "1") {

$("#msg").append("
[有数据]" + data.text);

evdata.data.btn.click();

}

//未从服务器得到数据,继续查询

if (data.success == "0") {

$("#msg").append("
[无数据]");

evdata.data.btn.click();

}

},

//Ajax请求超时,继续查询

error: function(XMLHttpRequest, textStatus, errorThrown) {

if (textStatus == "timeout") {

$("#msg").append("
[超时]");

evdata.data.btn.click();

}

}

});

});

Ajax.php

通过$_POST['time']来限制循环的超时时间,避免资源过度浪费。要注意的是浏览器不关闭的话,会一直请求下去......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<=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();

}

}

大家可以利用这种长轮询(COMET)方式,做一个在线聊天系统,若是成功的话,你肯定会觉得小有成就呢!~

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值