JAVA、PHP、前端、APP、网站开发 - 开发技术学习

开发技术学习 » 前端设计 » Jquery+php实现comet(附实例下载)

Jquery+php实现comet(附实例下载)

此文被围观3101 日期: 2013-03-19 分类 : 前端设计  标签:  ··
上一篇文章我们是写的用prototype+php实现了comet,本人对prototype不熟,为理解它的原理,所以用Jquery改写了一下,php代码没有变. [php] <?php set_time_limit(9990); $filename = dirname(__FILE__).'/data.txt'; // store new message in the file $msg = isset($_GET['msg']) ? $_GET['msg'] : ''; if ($msg != ''){ file_put_contents($filename,$msg,LOCK_EX); die(); } // infinite loop until the data file is not modified $lastmodif = isset($_GET['timestamp']) ? $_GET['timestamp'] : 0; $currentmodif = filemtime($filename); while ($currentmodif <= $lastmodif) // check if the data file has been modified { usleep(10000); // sleep 10ms to unload the CPU clearstatcache(); $currentmodif = filemtime($filename); } // return a json array $response = array(); $response['msg'] = file_get_contents($filename); $response['timestamp'] = $currentmodif; echo json_encode($response); flush(); [/php] html代码: [html] <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml">   <head>     <title>Comet demo</title>     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />     <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>     <script type="text/javascript">     var timestamp = 0;     var url = 'backend.php';     var error = false;     function connect(){         $.ajax({             data : {'timestamp' : timestamp},             url : url,             type : 'get',             timeout : 0,             success : function(response){                 var data = eval('('+response+')');                 error = false;                 timestamp = data.timestamp;                 $("#content").append('<div>' + data.msg + '</div>');             },             error : function(){                 error = true;                 setTimeout(function(){ connect();}, 5000);             },             complete : function(){                 if (error)                     // if a connection problem occurs, try to reconnect each 5 seconds                     setTimeout(function(){connect();}, 5000);                 else                     connect();             }         })     }     function send(msg){         $.ajax({             data : {'msg' : msg},             type : 'get',             url : url         })     }     $(document).ready(function(){         connect();     })     </script>   </head>   <body>      <div id="content">   </div>      <p>     <form action="" method="get" onsubmit="send($('#word').val());$('#word').val('');return false;">       <input type="text" name="word" id="word" value="" />       <input type="submit" name="submit" value="Send" />     </form>   </p>      </body> </html> [/html] 但是光这样是不足以投入使用的,在测试中本人发现两个问题:, b4 j$ d8 @ P! U% r 1. HTTP 1.1规定客户端不应该与服务器端建立超过两个的HTTP连接,新的连接会被阻塞。而IE系列8.0以下版本的浏览器就是这么做的,所以若同时打开两个浏览器窗口(IE8.0以下)或者是刷新了页面,程序就死掉了。 2. 通常情况下web服务器允许脚本最大执行时间是30秒,所以要让程序正常运行,就需要将服务器的脚本最大执行时间设置成无限,但似乎也不是上上策。 但事实证明php是可以很好地实现服务器推技术的,如phpfreechat即时聊天室,开心网和白社会的即时消息都是成功案例(它们都不会出现上面的两个问题)。 本例下载:jquery_php_comet

站点声明:部分内容源自互联网,为传播信息之用,如有侵权,请联系我们删除。

© Copyright 2011-2024 www.kfju.com. All Rights Reserved.
超级字帖 版权所有。 蜀ICP备12031064号      川公网安备51162302000234