项目地址:https://gitee.com/dhclly/IceDog.SignalR/tree/master/src/chat
demo的实现均来自官方的教程,教程地址:
ASP.NET Core SignalR 入门 | Microsoft Docs https://docs.microsoft.com/zh-cn/aspnet/core/tutorials/signalr?tabs=visual-studio&view=aspnetcore-2.2
配合使用 ASP.NET Core SignalR 和 TypeScript 以及 Webpack | Microsoft Docs https://docs.microsoft.com/zh-cn/aspnet/core/tutorials/signalr-typescript-webpack?view=aspnetcore-2.2&tabs=visual-studio
供遇到问题的小伙伴参考
SignalR 是什么?
ASP.NET Core SignalR 是一个开源代码库,它简化了向应用添加实时 Web 功能的过程。 实时 Web 功能使服务器端代码能够即时将内容推送到客户端。
SignalR 的适用对象:
SignalR 提供了一个用于创建服务器到客户端远程过程调用(RPC)的 API。 RPC 通过服务器端 .NET Core 代码调用客户端上的 JavaScript 函数。
以下是 ASP.NET Core SignalR 的一些功能:
源代码托管在 GitHub 上的 SignalR 存储库中。
SignalR 还适用于全新类型的 Web 应用程序,特别是需要从服务器高频率更新的应用程序,例如实时游戏。一个好的例子,请参阅ShootR 游戏。
SignalR 支持几种方法用于处理实时通信:
SignalR 会从服务器和客户端支持的功能中自动选择最佳传输方法
SignalR 使用中心在客户端和服务器之间进行通信。
“中心”是一种高级管道,允许客户端和服务器相互调用方法。 SignalR 自动处理跨计算机边界的调度,允许客户端和服务器相互调用方法。 可以将强类型参数传递给方法,从而启用模型绑定。 SignalR 提供两个内置中心协议:基于 JSON 的文本协议和基于 MessagePack 的二进制协议。 与 JSON 相比,MessagePack 创建的消息通常比较小。 旧版浏览器必须支持 XHR 2 才能提供 MessagePack 协议支持。
中心通过发送包含客户端方法的名称和参数的消息来调用客户端代码。 使用配置的协议对作为方法参数发送的对象进行反序列化。 客户端会尝试将方法名称与客户端代码中的方法匹配。 当客户端找到匹配项时,它会调用该方法并将反序列化的参数数据传递给它。
原文:https://www.cnblogs.com/DHclly/p/11332609.html