您可能已经听说过 Comet,因为它最近受到了一定的关注。Comet有时也称反向 Ajax或服务器端推技术(server-side push)。其思想很简单:将数据直接从服务器推到浏览器,而不必等到浏览器请求数据。听起来简单,但是如果熟悉Web应用程序,尤其是HTTP协议,那么您就会知道,这绝不简单。实现Comet风格的Web应用程序,同时保证在浏览器和服务器上的可伸缩性,这只是在最近几年才成为可能。目前一些主流网站都有类似的原理,例如:webQQ、开心网、白社会等等,它们中消息动态都是采用类似的技术,也许具体实现方式不一样;
作为一个技术人员,当你开始了解comet,都会或多或少有些兴奋,内心也会有蠢蠢欲试的冲动,再加上现在webQQ,baidu hi等网页聊天忽如一夜春风来,开得满网络都是,成了IT老大们下一个争夺的阵地。最近我和我的一个朋友也牛刀小试,用dwr的comet技术实现了简单在线聊天,当然我们不是为了争什么,只是为了满足作为技术人员的最原始的追求而已。不过其实它也简单,无非就是获取访问网站的用户列表,然后实现在线聊天就可以了。
先说说获取在线用户列表,当用户访问某页面时,onload事件,调用dwr反推到后台,后台先,新建一个用户信息,然后装进用户在线列表数组里(onlineUsers)。然后把onlineUsers当参数,反推到各个页面,让界面执行js,重新根据onlineUsers数组,生成在线列表;当用户关闭时,调用dwr反推,让它反推到各个在线用户页面后,执行删除该用户在信息。
然后说一下在线聊天,选中在线列表的人员,点击发起对话,调用dwr反推,去寻找与该用户信息匹配的会话,然后通过服务器反推执行代码到该用户页面,让页面执行对话信息的生成。当第一次连接建立后,dwr会记下双方的的信息(相当于一个访问地址),确立双方的关系后就能继续通话了,另外一个人也是这样处理。
效果,大家可以访问[url=http://www.jackshow.net]DEMO[/url],如果线上没有用户,你可以同时打开两个IE自个玩,或者把链接发给朋友,跟他们聊聊;如果线上已有用户,那你就可以直接跟她聊了,呵呵!
这个DEMO,得感谢我们团队的小冯,正是在他的努力下,这个DEMO才得以顺利完成,他的QQ是: 158948314,如果需要交流,大家可以直接加他,验证信息:javaeye
作为一个技术人员,当你开始了解comet,都会或多或少有些兴奋,内心也会有蠢蠢欲试的冲动,再加上现在webQQ,baidu hi等网页聊天忽如一夜春风来,开得满网络都是,成了IT老大们下一个争夺的阵地。最近我和我的一个朋友也牛刀小试,用dwr的comet技术实现了简单在线聊天,当然我们不是为了争什么,只是为了满足作为技术人员的最原始的追求而已。不过其实它也简单,无非就是获取访问网站的用户列表,然后实现在线聊天就可以了。
先说说获取在线用户列表,当用户访问某页面时,onload事件,调用dwr反推到后台,后台先,新建一个用户信息,然后装进用户在线列表数组里(onlineUsers)。然后把onlineUsers当参数,反推到各个页面,让界面执行js,重新根据onlineUsers数组,生成在线列表;当用户关闭时,调用dwr反推,让它反推到各个在线用户页面后,执行删除该用户在信息。
然后说一下在线聊天,选中在线列表的人员,点击发起对话,调用dwr反推,去寻找与该用户信息匹配的会话,然后通过服务器反推执行代码到该用户页面,让页面执行对话信息的生成。当第一次连接建立后,dwr会记下双方的的信息(相当于一个访问地址),确立双方的关系后就能继续通话了,另外一个人也是这样处理。
效果,大家可以访问[url=http://www.jackshow.net]DEMO[/url],如果线上没有用户,你可以同时打开两个IE自个玩,或者把链接发给朋友,跟他们聊聊;如果线上已有用户,那你就可以直接跟她聊了,呵呵!
这个DEMO,得感谢我们团队的小冯,正是在他的努力下,这个DEMO才得以顺利完成,他的QQ是: 158948314,如果需要交流,大家可以直接加他,验证信息:javaeye