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

宝塔面板企业版和专业版618年中活动 永久授权仅1888元+

我们一般的站长或者企业服务器配置WEB环境会用到免费版本的宝塔面板。但是如果我们需要较多的付费插件扩展,或者是有需要企业功能应用的,短期来说我们可能选择按件按月付费的比较好,但是如果我们长期使用的话,有些网友认为选择宝塔面板企业版或者专业版是比较划算的。这样在年中大促618的时候,我们也可以看到宝塔面板也有发布促销活动。企业版年付899元,专业版永久授权1888元起步。对于有需要的网友来说,还是值...

2021年国内/国外便宜VPS主机/云服务器商家推荐整理

2021年各大云服务商竞争尤为激烈,因为云服务商家的竞争我们可以选择更加便宜的VPS或云服务器,这样成本更低,选择空间更大。但是,如果我们是建站用途或者是稳定项目的,不要太过于追求便宜VPS或便宜云服务器,更需要追求稳定和服务。不同的商家有不同的特点,而且任何商家和线路不可能一直稳定,我们需要做的就是定期观察和数据定期备份。下面,请跟云服务器网(yuntue.com)小编来看一下2021年国内/国...

萤光云(13.25元)香港CN2 新购首月6.5折

萤光云怎么样?萤光云是一家国人云厂商,总部位于福建福州。其成立于2002年,主打高防云服务器产品,主要提供福州、北京、上海BGP和香港CN2节点。萤光云的高防云服务器自带50G防御,适合高防建站、游戏高防等业务。目前萤光云推出北京云服务器优惠活动,机房为北京BGP机房,购买北京云服务器可享受6.5折优惠+51元代金券(折扣和代金券可叠加使用)。活动期间还支持申请免费试用,需提交工单开通免费试用体验...

response.flush为你推荐
支持ipad支持ipad孩子appletraceroute网络管理工具traceroute是什么程序勒索病毒win7补丁求问win7 64位旗舰版怎么预防勒索病毒win10445端口win7系统不能被telnet端口号,端口、服务什么全都开了重庆电信宽带管家重庆电信宽带安装收费win7关闭135端口win7下怎么关135和8909端口迅雷下载速度迅雷下载速度真是太慢了ipad无法加入网络我的IPAD无法加入网络
apache虚拟主机 上海域名注册 双线主机租用 中国域名交易中心 瓦工 diahosting pw域名 mach iisphpmysql 老左博客 http500内部服务器错误 日本空间 一元域名 蜗牛魔方 泉州电信 免费吧 php空间购买 畅行云 万网空间 免费个人主页 更多