SignalR是.NET中实现实时通信的库,通过安装Microsoft.AspNetCore.SignalR包并调用AddSignalR注册服务,使用MapHub配置路由可完成基础设置;创建继承Hub的类定义方法如SendMessage,并用Clients.All.SendAsync推送消息,还可重写OnConnectedAsync处理连接逻辑;前端引入signalr.js后通过HubConnectionBuilder建立连接,调用start启动连接,on监听消息,invoke调用服务器方法,实现聊天、通知等实时功能。

在 .NET 平台中,SignalR 是一个强大的库,能轻松为应用添加实时功能。它自动处理底层连接细节,让服务器能在数据更新时立刻推送给客户端,适用于聊天、通知或实时仪表盘等场景。
配置 SignalR 服务与中间件
要在项目中启用 SignalR,需先安装 Microsoft.AspNetCore.SignalR NuGet 包。在 .NET Core 或更高版本中,打开 Program.cs 文件,将 SignalR 服务注册到依赖注入容器。
这样就完成了基础设置,接下来可以创建用于通信的中心(Hub)类。
创建并定义 Hub 类
Hub 是 SignalR 的核心组件,作为客户端与服务器通信的集线器。创建一个类继承自 Hub,并在其中定义可被客户端调用的方法。
- 例如,实现一个广播消息的方法 SendMessage,接收用户和内容参数
- 使用 Clients.All.SendAsync("ReceiveMessage", user, message) 向所有连接的客户端推送消息
- 也可重写 OnConnectedAsync 方法,在客户端连接时执行特定逻辑,比如发送欢迎信息或记录连接状态
客户端连接与消息处理
前端可通过 JavaScript 客户端库接入 SignalR 实时功能。引入 signalr.js 后,使用 HubConnectionBuilder 构建连接实例,并指向后端配置的 Hub 路径。
- 调用 connection.start() 建立连接
- 用 connection.on("ReceiveMessage", ...) 监听服务器推送的消息事件
- 通过 connection.invoke("SendMessage", user, msg) 主动调用服务器端方法
基本上就这些,整个流程清晰且易于集成到现有项目中。










