HTTP是无状态、单向的协议,用户只能够通过客服端向服务器发送请求并由服务器处理发回一个响应。若要实现聊天室、WEBQQ、在线客服、邮箱等这些即时通讯的应用,就要用到“ 服务器推送技术(Comet)”。

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

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

html:

  1. <div id="msg"></div>
  2. <input id="btn" type="button" value="测试" />

javascript:

这里使用AJAX请求data.php页面获得‘success’的值,请求的时间达到80秒。在这80秒中若没有从服务端返回‘success’则一直保持连接状态,直到有数据返回或‘success’的值为0才关闭连接。在关闭连接后在继续下一次的请求。

  1. $(function(){
  2. $("#btn").bind("click",{btn:$("#btn")},function(evdata){
  3. $.ajax({
  4. type:"POST",
  5. dataType:"json",
  6. url:"data.php",
  7. timeout:80000,     //ajax请求超时时间80秒
  8. data:{time:"80"}, //40秒后无论结果服务器都返回数据
  9. success:function(data,textStatus){
  10. //从服务器得到数据,显示数据并继续查询
  11. if(data.success=="1"){
  12. $("#msg").append("<br>[有数据]"+data.text);
  13. evdata.data.btn.click();
  14. }
  15. //未从服务器得到数据,继续查询
  16. if(data.success=="0"){
  17. $("#msg").append("<br>[无数据]");
  18. evdata.data.btn.click();
  19. }
  20. },
  21. //Ajax请求超时,继续查询
  22. error:function(XMLHttpRequest,textStatus,errorThrown){
  23. if(textStatus=="timeout"){
  24. $("#msg").append("<br>[超时]");
  25. evdata.data.btn.click();
  26. }
  27. }
  28. });
  29. });
  30. });

PHP:

在这里是无限的循环,循环的结束条件就是获取到了返回结果返回Json数据。

并且接受$_POST['time']参数来限制循环的超时时间,避免资源的过度浪费。(浏览器关闭不会发消息给服务器,使用可能一直循环下去)

  1. if(empty($_POST['time']))exit();
  2. set_time_limit(0);//无限请求超时时间
  3. $i=0;
  4. while (true){
  5. //sleep(1);
  6. usleep(500000);//0.5秒
  7. $i++;
  8. //若得到数据则马上返回数据给客服端,并结束本次请求
  9. $rand=rand(1,999);
  10. if($rand<=15){
  11. $arr=array('success'=>"1",'name'=>'xiaocai','text'=>$rand);
  12. echo json_encode($arr);
  13. exit();
  14. }
  15. //服务器($_POST['time']*0.5)秒后告诉客服端无数据
  16. if($i==$_POST['time']){
  17. $arr=array('success'=>"0",'name'=>'xiaocai','text'=>$rand);
  18. echo json_encode($arr);
  19. exit();
  20. }
  21. }

运行效果:在图中可以看到无数据的请求时间达到了40S,在40S的请求中若获得数据则请求关闭。

最新文章

  1. Linux学习之四--Nginx
  2. Linux下xampp集成环境安装配置方法 、部署bugfree及部署禅道
  3. HT for Web基于HTML5的图像操作(一)
  4. 天龙客户端的ResourceManager
  5. hdu 1517 博弈 **
  6. js实现时钟
  7. 前端---HTML
  8. Atitit.人力资源管理原理与概论
  9. Office 多版本共存
  10. 摄像机导致的粒子效果混乱出错变成贴图sprite显示在镜头前
  11. C# Datatable的Select方法
  12. 初探ExtJS(2)
  13. 【Docker】(1)---Docker入门篇
  14. k8s教程
  15. redis make jemalloc
  16. db2存储过程动态sql被截断
  17. Hadoop---hu-hadoop1: mv: cannot stat `/home/bigdata/hadoop-2.6.0/logs/hadoop-root-datanode-hu-hadoop1.out.4&#39;: No such file or directory
  18. maven使用及创建项目
  19. Oracle数据库多行记录转换一行并排序函数
  20. IIS - 虚拟目录与应用程序的异同

热门文章

  1. SpringBootSecurity学习(10)网页版登录之记住我功能
  2. java异常类的妙用
  3. UML图标含义及记忆方法
  4. 使用.net core3.0 正式版创建Winform程序
  5. python import cv2异常(dll load fail / windows server 2008)
  6. Windows10+YOLOv3实现检测自己的数据集(1)——制作自己的数据集
  7. LeetCode初级算法--数组01:只出现一次的数字
  8. 网络编程java
  9. Centos 7.2天兔(Lepus 3.8)数据库监控系统部署
  10. 基于 Web 端 3D 地铁站可视化系统