连接利用Response.Flush和iframe实现”服务器推”技术

response.flush  时间:2021-04-17  阅读:()

利用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

Buyvm:VPS/块存储补货1Gbps不限流量/$2起/月

BuyVM测评,BuyVM怎么样?BuyVM好不好?BuyVM,2010年成立的国外老牌稳定商家,Frantech Solutions旗下,主要提供基于KVM的VPS服务器,数据中心有拉斯维加斯、纽约、卢森堡,付费可选强大的DDOS防护(月付3美金),特色是1Gbps不限流量,稳定商家,而且卢森堡不限版权。1G或以上内存可以安装Windows 2012 64bit,无需任何费用,所有型号包括免费的...

丽萨主机122元/每季,原生IP,CN2 GIA网络

萨主机(lisahost)新上了美国cn2 gia国际精品网络 – 精品线路,支持解锁美区Netflix所有资源,HULU, DISNEY, StartZ, HBO MAX,ESPN, Amazon Prime Video等,同时支持Tiktok。套餐原价基础上加价20元可更换23段美国原生ip。支持Tiktok。成功下单后,在线充值相应差价,提交工单更换美国原生IP。!!!注意是加价20换原生I...

digital-vm:VPS低至$4/月,服务器$80/月,10Gbps超大带宽,不限流量,机房可选:日本新加坡美国英国西班牙荷兰挪威丹麦

digital-vm,这家注册在罗马尼亚的公司在国内应该有不少人比较熟悉了,主要提供VPS业务,最高10Gbps带宽,还不限制流量,而且还有日本、新加坡、美国洛杉矶、英国、西班牙、荷兰、挪威、丹麦这些可选数据中心。2020年,digital-vm新增了“独立服务器”业务,暂时只限“日本”、“新加坡”机房,最高也是支持10Gbps带宽... 官方网站:https://digital-vm.co...

response.flush为你推荐
enter苹果5realgoogleformgraphlegraph技术参数及要求:支持ipadoutput_buffering飞飞的官方网站是啥深圳市富满电子集团股份有限公司重庆网通中国联通重庆分公司的公司简介xp如何关闭445端口Windows XP 怎么关闭445端口,我是电脑小白,求各位讲详细点
国外主机空间 宿迁服务器租用 香港服务器99idc 台湾服务器 香港cdn iisphpmysql 密码泄露 镇江联通宽带 嘟牛 免费全能空间 免费个人网站申请 华为4核 个人空间申请 php空间推荐 183是联通还是移动 什么是服务器托管 100mbps 优酷黄金会员账号共享 lick 国内域名 更多