SignalR是.net 开源库,用于构建须要实时进行用户交互和数据更新的web应用,如在线聊天,游戏,天气等实时应用程序,且简化了构建实时应用的过程,包括服务端库和js端库,继承了数种常见传输方式,如long polling,websocket等,并提供相应的api供开发人员选择。项目的流程图以下:前端
一、新建立一个.net core 2.2 web application 项目git
二、添加SignalR客户端文件github
在添加这个文件时按照官方给出的步骤操做,个人vs一直会卡主,所以我直接从其余项目复制过来,而后放在wwwroot文件夹下面的lib/signalr下,我复制了signalr.js和signalr.min.js文件便可。web
文件请移步至个人github上下载案例。api
三、建立SignalR中心
此中心用来客户端与服务端的沟通桥梁。又叫作高级管道。
新建一个文件夹命名为SignalRChat,而后建立一个类,如ChatHub,此类继承与Hub
Hub 类管理链接、组和消息。安全
using Microsoft.AspNetCore.SignalR; using System.Threading.Tasks; namespace SignalRChat.Hubs { public class ChatHub : Hub { public async Task SendMessage(string user, string message) { await Clients.All.SendAsync("ReceiveMessage", user, message); } } }
特别注意在服务中心中的这个"ReceiveMessage",是能够传参的,如修改为一下的方式:微信
public async Task SendMessage(string method,string user, string message) { await Clients.All.SendAsync(method, user, message); }
四、在项目中的startup.cs 注入SignalR的配置。
在ConfigureServices 中注入signalr到container中。websocket
public void ConfigureServices(IServiceCollection services) { services.Configure<CookiePolicyOptions>(options => { // This lambda determines whether user consent for non-essential cookies is needed for a given request. options.CheckConsentNeeded = context => true; options.MinimumSameSitePolicy = SameSiteMode.None; }); services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2); services.AddSignalR(); }
在Configure 中注入中间件cookie
app.UseSignalR(a=> { a.MapHub<ChatHub>("/chatHubs"); });
五、服务端已经配置完成,接下来轮到 前端配置了。
前端页面中须要添加 Signalr.js文件以及咱们自定义的chat.js此脚本用来链接SignalR以及发送接收用的数据用的。
注:下图中的两处标红的位置名称要一致,不然会形成数据没法接收,这边的名称就是在SignalR中心中的自定义的方法标签。app
六、能够运行应用
我开了两个页面,一个发送,一个就能够接收了。
至此,SignalR简单demo已OK
此案例之间简单的进行通讯,尚未涉及到数据安全、身份验证和受权等。后期将会继续深刻研究。
github-demo:https://github.com/LouieGuo/SignalRLouie
参考文档:入门:https://docs.microsoft.com/zh-cn/aspnet/core/tutorials/signalr?tabs=visual-studio&view=aspnetcore-2.2
asp.net core 交流群:787464275 欢迎加群交流
若是您认为这篇文章还不错或者有所收获,您能够点击右下角的【推荐】按钮精神支持,由于这种支持是我继续写做,分享的最大动力!
微信公众号:欢迎关注 QQ技术交流群: 欢迎加群