【web】http长连接技术(1)comet介绍

本文介绍Comet技术,一种利用HTTP长连接实现服务器推送的方式。文章探讨了两种模型:基于iframe和使用ajax的长轮询(long-polling)。Comet技术克服了IE浏览器的显示问题,并提供了JavaScript封装的对象。

   标签:web javascript comet php

主要参考下面3个链接:
http://www.ibm.com/developerworks/cn/opensource/..(抱歉,这个不全了。搜一下comet很容易找到)
Comet:基于 HTTP 长连接的“服务器推”技术
http://www.zeitoun.net/index.php?2007/06/22/46-how-to-implement-comet-with-php
“How to implement COMET with PHP”:提供的 comet-iframe.tar.gz 使用 iframe/htmlfile 封装了一个 JavaScript comet 对象,支持 IE、Mozilla Firefox 浏览器。
http://alex.dojotoolkit.org/?p=538
“What else is burried down in the depth’s of Google’s amazing JavaScript?”(Alex Russel,2006 年 2 月):Alex 在这篇文章里介绍了如何使用“htmlfile”ActiveX 控件解决 iframe 请求长连接时 IE 的加载显示问题。

   一直对server push技术比较感兴趣,但是之前的server push技术是基于netscape浏览器的,而目前占统治地位的IE却不支持。
   不久前再次搜索时,发现了http长连接和新名词:Comet。
   其实,http长连接并不是新技术。在最早的perl –cgi上就很容易实现。只不过没有流行。Comet不过是引入了一点对象封装的概念,对于客户体验有了一定的改善。其中有一点革命性的建议:长连接不用于返回html页面,而是返回javascript函数.
   这样,就可以很好地实现MVC模型。Web页面通过javascript实现展现。后端的控制程序通过push js函数来控制展现。
   BTW,目前的一些web game,如myj和miu就是用的这个技术。
   这里有两种模型:一是基于iframe,把长连接放在页面的一个隐藏iframe中。另一种,是使用ajax的长轮询(long-polling)方式。
   使用 iframe 请求一个长连接有一个很明显的不足之处:IE、Morzilla Firefox 下端的进度栏都会显示加载没有完成,而且 IE 上方的图标会不停的转动,表示加载正在进行。Google 的天才们使用一个称为“htmlfile”的 ActiveX 解决了在 IE 中的加载显示问题。
   Zeitoun 网站提供的 comet-iframe.tar.gz,封装了一个基于 iframe 和 htmlfile 的 JavaScript comet 对象,支持 IE、Mozilla Firefox 浏览器,可以作为参考。

Comet4J(Comet for Java)是一个纯粹基于AJAX(XMLHTTPRequest)的服务器推送框架,消息以JSON方式传递,具备长轮询、长连接、自动选择三种工作模式。 功能特性 推送消息广播。 推送定向消息。 提供连接上线前、上线、下线前、下线、发送消息等多种可处理事件。 消息缓存机制,确保长轮询工作模式下不丢失消息。 客户端正常下线,服务端可立即感知。 客户端异常停止工作,服务端可定时检查并感知。 以注册通道应用的方式,让开发者对框架功能进行扩展,实现自己的应用。 框架特性 独立小巧,不依赖于第三方包。 与应用紧密集成,无需独立应用或服务器。 与Session无关的连接机制,为开发人员提供最大程度的功能可控性。 面向事件编程,客户端与服务器端均为事件驱动开发模式,提供了良好的可扩展性机制。 各项性能参数均可配置。 支持多种主流浏览器,并支持Air应用环境。 服务器支持情况 Tomcat6、Tomcat7 浏览器支持情况 支持XMLHTTPRequest对象的浏览器均可支持长轮询工作模式,但不一定能够支持长连接。 | 浏览器/平台 | 版本 | 长轮询 | 长连接 | |:-----------|:-------|:--------|:--------| | Internet Explorer | 6,7,8,9 | √ | X | | FireFox | 3.0+(更底版本未知) | √ | √ | | Chrome | 7.0+(更底版本未知) | √ | √ | | Safari | 5+(更底版本未知) | √ | √ | | Opera | 11.10+(更底版本未知) | √ | X | | Air | 1.5+(更底版本未知) | √ | √ | | IOS(Iphone/Ipad)| 3.1+(更底版本未知) | √ | √ | | Android | 未测试 | 未知 | 未知 | | BlackBerry | 未测试 | 未知 | 未知 |
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值