利用Response.Flush和iframe实现”服务器推”技术
通过在HTML页面里陷入一个隐藏的iframe然后将这个iframe的src属性设为对一个长连接的请求利用chunked传输response 服务器端就能源源不断地往客户推送数据。
基于流方式的”服务器推”模型
服务端在接到客户端的请求时通过Response的Flush()方法发送数据可以使用定时器的方式发送数据没有数据也发送”无数据” ,让客户端保持长连接直至客户端断开连接请求结束。每次数据传送不会关闭连接连接只会在通信出现错误时或是连接重建时关闭一些防火墙常被设置为丢弃过长的连接 服务器端可以设置一个超时时间 超时后通知客户端重新建立连接并关闭原来的连接 。
实现代码
页面Default.aspx用来展示数据
1: 数据列表 o<br />
2: <div id="con" style=" width:400; height:200px; border: 1pxsolid #FF0">
3: </div>
4: <iframe id="flush" src="Flush.aspx" style=" display:none" />
5:ifame的src对应的Flash.aspx后台代码模拟后台发送数据
1: protected void Page_Load(object sender, EventArgs e)
2: {
3: string startHTML = "<!DOCTYPE HTML PUBLIC \"-//W3C//DTDXHTML 1.0 Transitional//EN\"
\"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">" +Environment.NewLine
4: + "<html xmlns=\"http://www.w3.org/1999/xhtml\" >" +Environment.NewLine
5: + "<head>" + Environment.NewLine
6: + "</head>" + Environment.NewLine
7: + "<body>" + Environment.NewLine;
8:
9: startHTML += new String(' ' , 1024) + Environment.NewLine;
10:
11: Response.Write(startHTML) ;
12: Response.Flush() ;
13:
14: string data = "<scripttype=\"text/javascript\">parent. $('#con' ) .append(\"{0}\") ;</script>";
15: Response.Write(string.Format(data, "开始发送数据<br/>") ) ;
16: Response.Flush() ;
17:
18: int index = 0;
19: while (true)
20: {
21: System.Threading.Thread.Sleep(2000) ;
22: if (index % 2 == 0)
23: {
24: Response.Write(string.Format(data,
DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "服务端发送数据<br/>") ) ;
25: }
26: else
27: {
28: Response.Write(string.Format(data,
DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "无数据发送<br/>") ) ;
29: }
30: Response.Flush() ;
31:
32: index++;
33: }
34: }
35:
运行Default.aspx的结果
使用iframe请求一个长连接有一个很明显的不足之处 IE、 MorzillaFirefox下端的进度栏都会显示加载没有完成而且IE上方的图标会不停的转动表示加载正在进行刷新当前页面反应也是会很慢。
解决IE的进度栏显示加载没有完成可以使用一个称为“htmlfile”的ActiveX是Google的天才们使用的方法该控件也被用到gmail+gtalk产品中。
修改Default.aspx的页面代码
1: 数y据Y列D表í o<br />
2: <div id="con" style=" width:400; height:200px; border: 1pxsolid #FF0">
3: </div>
4: <script type="text/javascript">
5: function getData(d)
6: {
7: $("#con") .append(d) ;
8: }
9:
10: function rpc_iframe() {
11: var transferDoc = new ActiveXObject("htmlfile") ;
12: transferDoc.open() ;
13: transferDoc.write("<html>")
14: transferDoc.write("<div><iframesrc=\"Flush.aspx\"></iframe></div>") ;
15: transferDoc.close("</html>") ;
16: transferDoc.parentWindow.getData = getData;
17: setInterval (function () { } , 10000) ; //不加这句会使连接断开
18: }
19:
20: rpc_iframe() ;
21: </script>
22:
修改Flush.aspx.cs代码
1: //string data = "<scripttype=\"text/javascript\">parent. $('#con' ) .append(\"{0}\") ;</script>";
2: string data = "<scripttype=\"text/javascript\">parent.getData(\"{0}\") ;</script>";
3:
Tag标签: Comet,服务器推,Response.Flush, iframe,htmlfile
关于HostDare服务商在之前的文章中有介绍过几次,算是比较老牌的服务商,但是商家背景财力不是特别雄厚,算是比较小众的个人服务商。目前主流提供CKVM和QKVM套餐。前者是电信CN2 GIA,不过库存储备也不是很足,这不九月份发布新的补货库存活动,有提供九折优惠CN2 GIA,以及六五折优惠QKVM普通线路方案。这次活动截止到9月30日,不清楚商家这次库存补货多少。比如 QKVM基础的五个方案都...
Hostkey.com成立于2007年的荷兰公司,主要运营服务器出租与托管,其次是VPS、域名、域名证书,各种软件授权等。hostkey当前运作荷兰阿姆斯特丹、俄罗斯莫斯科、美国纽约等数据中心。支持Paypal,信用卡,Webmoney,以及支付宝等付款方式。禁止VPN,代理,Tor,网络诈骗,儿童色情,Spam,网络扫描,俄罗斯色情,俄罗斯电影,俄罗斯MP3,俄罗斯Trackers,以及俄罗斯法...
RAKsmart 商家这几年还是在做事情的,虽然他们家顺带做的VPS主机并不是主营业务,毕竟当下的基础云服务器竞争过于激烈,他们家主营业务的独立服务器。包括在去年开始有新增多个数据中心独立服务器,包括有10G带宽的不限流量的独立服务器。当然,如果有需要便宜VPS主机的他们家也是有的,比如有最低月付1.99美元的美国VPS主机,而且可选安装Windows系统。这里商家有提供下面六款六月份的活动便宜V...