1. 前言

本文是根据网上前人的总结得出的。

环境: SignalR2.x,VS2015,Win10

2. 开始开发

1)新建一个MVC项目,叫做SignalRDemo

2)安装SignalR包

Install-Package Microsoft.AspNet.SignalR

Install-Package Microsoft.AspNet.SignalR.Client

安装完包后会有相应的引用和js文件

3)新建startup文件,用来启动SignalR

代码如下:

using System;
using System.Threading.Tasks;
using Microsoft.Owin;
using Owin; [assembly: OwinStartup(typeof(SignalRDemo.SignalR.StartupSignalR))] namespace SignalRDemo.SignalR
{
public class StartupSignalR
{
public void Configuration(IAppBuilder app)
{
// 有关如何配置应用程序的详细信息,请访问 http://go.microsoft.com/fwlink/?LinkID=316888
app.MapSignalR();//启动SignalR
}
}
}

4)新建Hub类,MyHub。此类的作用是用来与客户端的连接。

可以看到[HubName("myHub")]的注解,是用来与前端JS做绑定

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using System.Web;
using Microsoft.AspNet.SignalR;
using Microsoft.AspNet.SignalR.Hubs; namespace SignalRDemo.SignalR
{ [HubName("myHub")]
public class MyHub : Hub
{ //当连接hub实例时被调用
public override Task OnConnected()
{
string connId = Context.ConnectionId;
return base.OnConnected();
} //当失去连接或链接超时时被调用
public override Task OnDisconnected(bool stopCalled)
{
//stopCalled=true时,客户端关闭连接
//stopCalled=false时,出现链接超时
return base.OnDisconnected(stopCalled);
} //重新连接时被调用
public override Task OnReconnected()
{
return base.OnReconnected();
} }
}

上面已经新建了与前端连接类。下面我们开始不同的调用方式

至此,我们创建环境已经结束。

3. 不同调用方式

1)前端调用后端

前端html:

myHub是HubName注解属性。2个js一定要引用:Jquery、SignalR。scripts中有src='/SignalR/hubs',其中SignalR是我们服务器端的文件夹,hubs是不存在的文件夹。

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
<meta charset="utf-8"/>
<script src="/scripts/jquery-1.10.2.min.js"></script>
<!--Reference the SignalR library. -->
<script src="/scripts/jquery.signalR-2.2.1.js"></script>
<!--Reference the autogenerated SignalR hub script. -->
<script src='/SignalR/hubs'></script>
<!--Add script to update the page and send messages.-->
<script type='text/javascript'>
$(function () {
//引用自动生成的代理,myHub是HubName注解属性
var myHub = $.connection.myHub;
//开始连接
$.connection.hub.start().done(function () {
//客户端发送信息到服务器
myHub.server.Send($.connection.hub.id);
});
});
</script>
</head>
<body> </body>
</html>

后端MyHub类中,添加方法:

       //客户端发送信息到服务器
public void Send(string message)
{ }

访问html,就能直接调用Send方法了。

至此,前端调用后端,结束。

2)后端主动调用前端

前端代码,增加了后端调用前端JS

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
<meta charset="utf-8"/>
<script src="/scripts/jquery-1.10.2.min.js"></script>
<!--Reference the SignalR library. -->
<script src="/scripts/jquery.signalR-2.2.1.js"></script>
<!--Reference the autogenerated SignalR hub script. -->
<script src='/SignalR/hubs'></script>
<!--Add script to update the page and send messages.-->
<script type='text/javascript'>
$(function () {
//引用自动生成的代理,myHub是HubName注解属性
var myHub = $.connection.myHub; //后端调用前端
myHub.client.serverSend2Client = function (message) {
console.log("serverSend2Client message=" + message);
}; //开始连接
$.connection.hub.start().done(function () {
//客户端发送信息到服务器
myHub.server.send($.connection.hub.id);
console.log("connection.hub.id=" + $.connection.hub.id);
});
});
</script>
</head>
<body> </body>
</html>

后端代码:

我们新建一个Notifier的静态类,好处是让其他类可以灵活地调用,你也可以把方法写在Hub类中

serverSend2Client方法是与前端绑定的JS方法,可以看到前端也有此方法。

    public static class Notifier
{
private static readonly IHubContext Context = GlobalHost.ConnectionManager.GetHubContext<MyHub>(); public static void ServerSend2ClientMethod(string connectionId, string message)
{
//注册后端与前端的方法serverSend2Client。connectionId是判断发送给哪个前端
Context.Clients.Client(connectionId).serverSend2Client(message);
} }

我们在Controller中,添加代码,达到,后端主动调用前端的目的。

注意,connectionId在后端与前端后可以获取。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using SignalRDemo.SignalR; namespace SignalRDemo.Controllers
{
public class DefaultController : Controller
{
// GET: Default
public ActionResult Index()
{
//接收connId,connId是前端与后端连通的唯一标识
string connId = Request["connId"] ?? "";
//调用 后端主动调用前端的方法
Notifier.ServerSend2ClientMethod(connId, Math.Round(1000.0) + ""); return View();
}
}
}

至此,后端主动调用前端代码结束。

代码下载地址GitHub  https://github.com/cjt321/SignalRDemo

如果你的部署是负载均衡,多台服务器,可以查看Redis与SignalR的配置。C# BS消息推送 负载均衡-SignalR&Redis的配置(三)

可以关注本人的公众号,多年经验的原创文章共享给大家。

最新文章

  1. 朴素贝叶斯算法下的情感分析——C#编程实现
  2. winrt组件库(包括翻书组件)
  3. JavaWeb学习之Path总结、ServletContext、ServletResponse、ServletRequest(3)
  4. Linux常用命令学习1---(安装、文件系统、目录操作命令cd ls mv cp rm mkdir、链接命令ln……)
  5. iOS 进阶 第十五天(0417)
  6. [原创]mac终端前面的计算机名怎么改??
  7. 详解HTML&lt;head&gt; 头标签元素的意义以及使用场景
  8. 09.25日记(2014年9月25日23:22:06)用java这么多年面向对象我真的懂了吗,测试先行理念会玩吗
  9. javascript小数四舍五入
  10. 【iOS开发之静态库、动态库】
  11. fastjson的常用使用方法
  12. linux下执行sh文件报错:oswatcher_restart.sh: line 13: ./startOSW.sh: Permission denied
  13. 只能从脚本中调用在类定义上有[ScriptService]属性的Web服务问题的解决方案
  14. 1、Web应用程序中的安全向量 -- XSS跨站脚本攻击
  15. gcc 简单编译流程
  16. mongo 让字段自增或自减
  17. 洛谷P1731 生日蛋糕
  18. mysql理论结合实际篇(一)
  19. 大牛的距离(笑cry)精简算法
  20. iOS UIButton 图片文字左右互移 位置对调 解决方案

热门文章

  1. 20个高级Java面试题汇总
  2. CentOS安装JDK和安装Glassfish
  3. WPF中获取鼠标相对于桌面位置
  4. MVC Razor视图引擎的入门
  5. Android面试技巧 找安卓开发工作同学可以看看!
  6. android studio安卓项目出现Error: Default Activity Not Found错误无法编译的解决方案
  7. Python之路Day20-Django一对一(多)以及Ajax
  8. 关于DOM的一些笔记(一)
  9. 安装OS X虚拟机错误vcpu-0:VERIFY vmcore/vmm/main/physMem_monitor.c:1123
  10. 2016huasacm暑假集训训练五 H - Coins