asp.net signalR 专题—— 第三篇 如何从外部线…
2018-06-17 21:20:14来源:未知 阅读 ()
在前面的两篇文章中,我们讲到的都是如何将消息从server推向client,又或者是client再推向server,貌似这样的逻辑没什么异常,但是放在真实
的环境中,你会很快发现有一个新需求,如何根据第三方系统的数据变化来即时的将新数据推送到各个客户端,比如下面这样:
ok,原理就是上面的这张图,如果我们Server中的“监控程序”发现有更新,这个时候,监控程序需要将更新的数据送给server程序,然后由server程序
推送到各个客户端,那下面我们该怎么做到呢?
一:GlobalHost 属性
首先我们简单的看一下它的解释,叫做“提供对默认主机信息的访问”,可以看到,这是一个所谓的全局设置,里面的5个属性,个个都非常重要,因为
对他们的设置,影响的都是全局性的,好了,作为这篇我们关注的就是其中之一ConnectionManager属性,如下图:
它呢,就是获取你当前的Connection连接,好了,废话不多说,我们来做一个例子看一看。
二:实例演示
1. 伪造“外部系统”
在这里我就Fake一个单独页面(mytest.aspx),假装从外面获取到了"我是mytest.aspx"这条数据,如下:
在上图中,你也看到了GetConnectionContext方法是接受一个泛型的参数,而这个“泛型参数”,就是你的PersistentConnection实现类,这里也就
是MyConnection1,当然这里不光可以访问Persistent,还可以访问Hub类,这个我们放到后续和大家讲解。
2. 开启两个客户端
开启这两个就是为了连接到我们的server,假装多用户,也就是PersistentConnection类,如下:
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title></title> <meta charset="utf-8" /> </head> <body> <script src="/scripts/jquery-1.10.2.js"></script> <script src="/scripts/jquery.signalR-2.1.2.js"></script> <!--<script src="/signalr/js"></script>--> <script src="scripts/myjs.js"></script> <script type="text/javascript"> var conn = $.connection("/myconnection"); conn.start().done(function (data) { console.log(data.id); }); conn.received(function (data) { console.log(data); }); </script> </body> </html>
public class MyConnection1 : PersistentConnection { protected override Task OnConnected(IRequest request, string connectionId) { Debug.WriteLine("OnConnected"); return Connection.Send(connectionId, "Welcome!"); } protected override Task OnReceived(IRequest request, string connectionId, string data) { Debug.WriteLine(data); return Connection.Send(connectionId, data); } protected override Task OnDisconnected(IRequest request, string connectionId, bool stopCalled) { Debug.WriteLine("OnDisconnected"); return base.OnDisconnected(request, connectionId, stopCalled); } protected override Task OnReconnected(IRequest request, string connectionId) { Debug.WriteLine("OnReconnected"); return base.OnReconnected(request, connectionId); } }
现在两个client都开启了,然后各自都收到了server的欢迎信息,以及各自和server通信的标识。
3. 访问mytest页面,模拟通知各个客户端,如下图:
好了,这个也是本篇课程所讲的主要东西,虽然不显眼,但是在真实环境中对您确实非常的有帮助~~~
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- Log4net入门(ASP.NET MVC 5篇) 2018-06-23
- C#和ASP.NET之事件 2018-06-23
- 总结一下工作中遇到的NPOI以及在ASP.NET MVC中的使用 2018-06-22
- 【Asp.Net】后台生成控件并绑定事件 2018-06-22
- ASP.NET Boilerplate Zero启动方式 2018-06-22
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash