SignalR是一个实现实时推送的库,可以做聊天室,也可以做站内即时消息。即时通讯非常简单

SignalR是什么?
ASP.NET SignalR 是为 ASP.NET 开发人员提供的一个库,可以简化开发人员将实时 Web 功能添加到应用程序的过程。实时 Web 功能是指这样一种功能:当所连接的客户端变得可用时服务器代码可以立即向其推送内容,而不是让服务器等待客户端请求新的数据。
ASP .NET SignalR 是一个ASP .NET 下的类库,可以在ASP .NET 的Web项目中实现实时通信。什么是实时通信的Web呢?就是让客户端(Web页面)和服务器端可以互相通知消息及调用方法,当然这是实时操作的。
WebSockets是HTML5提供的新的API,可以在Web网页与服务器端间建立Socket连接,当WebSockets可用时(即浏览器支持Html5)SignalR使用WebSockets,当不支持时SignalR将使用其它技术来保证达到相同效果。
SignalR当然也提供了非常简单易用的高阶API,使服务器端可以单个或批量调用客户端上的JavaScript函数,并且非常 方便地进行连接管理,例如客户端连接到服务器端,或断开连接,客户端分组,以及客户端授权,使用SignalR都非常 容易实现。
SignalR 将与客户端进行实时通信带给了ASP .NET 。当然这样既好用,而且也有足够的扩展性。以前用户需要刷新页面或使用Ajax轮询才能实现的实时显示数据,现在只要使用SignalR,就可以简单实现了。
最重要的是您无需重新建立项目,使用现有ASP .NET项目即可无缝使用SignalR。(百度百科)

1:添加引用和js
在这里插入图片描述

二、代码
用的是signalr2,需要新建Startup.cs类,编码如下:

using Microsoft.Owin;
using Owin;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
[assembly: OwinStartup(typeof(SignalrDemo.Startup))]
namespace SignalrDemo
{
    
       
    public class Startup
    {
    
    
        public void Configuration(IAppBuilder app)
        {
    
    
            app.MapSignalR();
 
        }
    }
}

后台还需要群发消息的ChatHub.cs类,编码如下:

using Microsoft.AspNet.SignalR;
using Microsoft.AspNet.SignalR.Hubs;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
 
namespace SignalrDemo.Hubs
{
    
    
    [HubName("chatHub")]
    public class ChatHub:Hub
    {
    
    
        public void AddToRoom(string groupId,string userName)
        {
    
    
            //将分组Id放到上下文中
            Groups.Add(Context.ConnectionId, groupId);
            //群发人员进入信息提示
            Clients.Group(groupId, new string[0]).addUserIn(groupId,userName);
        }
        public void Send(string groupId,string detail,string userName)
        {
    
    
            //Clients.All.addSomeMessage(detail);//群发给所有
            //发给某一个组
            Clients.Group(groupId, new string[0]).addSomeMessage(groupId, detail,userName);
        }
    }
}

前端代码如下:

@{
    
    
    ViewBag.Title = "Index";
    Layout = null;
}
<p>
    <span>房间号:</span>
    <input type="text" id="groupId" />
    <span>用户名:</span>
    <input type="text" id="userName" />
    <button id="joinRoom">加入聊天室</button>
</p>
<p>
    <span>消息:</span>
    <input type="text" id="message" />
    <button id="send">发送</button>
</p>
<div>
    <ul id="contentMsg">
    </ul>
</div>
<script src="~/Scripts/jquery-1.8.2.min.js"></script>
<script src="~/Scripts/jquery.signalR-2.0.2.min.js"></script>
<script src="~/signalr/hubs"></script>
<script type="text/javascript">
    $(function () {
    
    

        var chat = $.connection.chatHub;
        chat.hubName = 'chatHub';
        chat.connection.start();

        chat.client.addSomeMessage = function (groupId, detail,userName) {
    
    
            console.info("广播消息:" + detail);
            $("#contentMsg").append("<li>" + userName+": " + detail + "</li>");
        };

        chat.client.addUserIn = function (groupId,userName) {
    
    
            $("#contentMsg").append("<li>" + userName + "进入该聊天室!</li>");
        };
        $.connection.hub.logging = true;//启动signalr状态功能

        //加入聊天室 
        $("#joinRoom").click(function () {
    
    
            var groupId = $("#groupId").val();
            var userName = $("#userName").val();
            chat.server.addToRoom(groupId,userName);
        });
        //发送消息
        $("#send").click(function () {
    
    
            var detail = $("#message").val();
            var groupId = $("#groupId").val();
            var userName = $("#userName").val();
            chat.server.send(groupId,  detail, userName);
        });

    });
</script>

三、注意的地方。

1.在前端页面中引用了

这个js。这是在项目中找不到,是有signalr自己生成作为桥接的js。

2.在引用过程中可能会出现一种错误。
“未能加载文件或程序集“Newtonsoft.Json, Version=4.5.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed”或它的某一个依赖项。找到的程序集清单定义与程序集引用不匹配。 (异常来自 HRESULT:0x80131040)”
此时可以尝试下载web.config中加上下面一段:

<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">

B:-->
<dependentAssembly>
<assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30AD4FE6B2A6AEED" culture="neutral"/>
<bindingRedirect oldVersion="0.0.0.0-6.0.0.0" newVersion="6.0.0.0"/>
</dependentAssembly>
<!--E-->

</assemblyBinding>


</runtime>

我感觉比较详细的例子:https://www.cnblogs.com/lgxlsm/p/7490139.html(来自一位大神)
推荐SignalR官网的一个Demo:http://www.asp.net/signalr/overview/getting-started/tutorial-getting-started-with-signalr
SignalR官网:http://www.asp.net/signalr

猜你喜欢

转载自blog.csdn.net/u014249305/article/details/107309841
今日推荐