日期:2014-05-16 浏览次数:20614 次
今天研究试验了一下“服务器推”的comet技术。
?
之前上GOOGLE GMAIL时也很好奇它的那个即时聊天框,居然可以在WEB页面中做到类似于QQ的聊天框,很有意思。
最近才知道这个技术一直被WEB技术探讨,——WEB服务器如何向指定的客户端推送数据?
因为HTTP传输机制的限制,一次HTTP请求就完整的包括了TCP建立、TCP传输 和TCP关闭。我们在一个页面被访问完毕之后,这次连接
就完全释放。那么服务器就无法再与这个客户端通信了。
?
由于页面超时时间一般为30秒,服务器也无法抓住一次HTTP请求不放开,所以这个问题一直在WEB开发技术上作为一个热点问题存在
。
?
直到AJAX的出现,我们出现了以AJAX为基础的HTTP长连接技术:comet
?
今天我们就来体验一下它功能!
?
我们来实现一个简单的功能,服务器端向指定客户端推送网页。
客户端使用一个ID登录之后,服务器端可以向指定ID推送网页,客户端收到之后应该显示出来。
?
我先在网上找了一个著名的comet教程,comet-ajax的一个聊天室示例程序,在此基础上改。
?
看了一下它的基本思想是:
?
客户端上来就创建AJAX长连接,有人发言之后,服务器端修改一个txt文件,该文件修改导致启动 ajax回馈,json格式回写,客户端
AJAX得到数据,调用javascript脚本呈现。
?
我们需要改成:
客户端上来通过ID登录,启动AJAX长连接,服务器端选择ID,输入URL,点击推送后,修改该txt文件,包括指定用户ID和URL,启动
ajax回馈,客户端得到数据,判断是否推送给本机,若是,则调用javascript在iframe中呈现该页面。
噼里啪啦很简单的敲了几行代码,就修改成功了!
?
看看我们的成果
?
?
同时推到4个用户。
?
重要代码:
?
<?php require_once('connectdb.php'); $id = $_GET['id']; $exec = "update user set online=1 where id like $id"; mysql_query( $exec ); echo "your id is [".$id."]<br>"; ?> <div id="content"> </div> <mce:script type="text/javascript" src="prototype.js" mce_src="prototype.js"></mce:script> <mce:script type="text/javascript"><!-- var Comet = Class.create(); Comet.prototype = { timestamp: 0, url: './backend.php', noerror: true, initialize: function() { }, connect: function() { this.ajax = new Ajax.Request(this.url, { method: 'get', parameters: { 'timestamp' : this.timestamp }, onSuccess: function(transport) { // handle the server response var response = transport.responseText.evalJSON(); this.comet.timestamp = response['timestamp']; this.comet.handleResponse(response); this.comet.noerror = true; }, onComplete: function(transport) { // send a new ajax request when this request is finished if (!this.comet.noerror) // if a connection problem occurs, try to reconnect each 5 seconds setTimeout(function(){ comet.connect() }, 5000); else this.comet.connect(); this.comet.noerror = false; } }); this.ajax.comet = this; }, disconnect: function() { }, handleResponse: function(response) { var s = response['msg']; var id = s.substr(0, 1); var url = s.substr(1,s.length-1); var url = "http://"+url; if( id == <?php echo $id ?> ) $('content').innerHTML = '<iframe height="100%" width="100%" src="'+url+'" mce_src="'+url+'"/>'; }, doRequest: function(request) { new Ajax.Request(this.url, { method: 'get', parameters: { 'msg' : request } }); } } var comet = new Comet(); comet.connect(); // --></mce:script>
?