• Vue 使用SignalR.JS与Microsoft.AspNetCore.SignalR实时通讯


    针对于Web与其他应用的的通讯,在.Net中,SignalR是一个不错的选择,在前后端没有分离的时候,直接引用对应的signalr.js文件即可; 这里主要记录Vue与Asp.netcore 前后端分离通过signalR通讯实践;

    服务端即Asp.net Core 程序

    前提:通过Nugut 引入Microsoft.AspNetCore.SignalR 包

    首先编写自己的Hub  

    1. public class ChatHub:Hub
    2. {
    3. public Task SendMsg(ChatMessageInfo info)
    4. //这里的Show代表是客户端的方法,具体可以细看SignalR的说明
    5. return Clients.All.SendAsync("Show", info.UserName + ":" + info.Message);
    6. }
    7. }
    8. public class ChatMessageInfo
    9. {
    10. public string UserName { get; set; }
    11. public string Message { get; set; }
    12. }

    or 

    1. using Microsoft.AspNetCore.SignalR;
    2. using System;
    3. using System.Collections.Generic;
    4. using System.Linq;
    5. using System.Threading.Tasks;
    6. namespace MaintainceSysAPI
    7. {
    8. public class MsgHub : Hub
    9. {
    10. private IList<string> userList = UserInfo.userList;
    11. public readonly static Dictionary<string, string> _connections = new Dictionary<string, string>();
    12. public Task SendMsg(string msg)
    13. {
    14. return Clients.All.SendAsync("ShowMsg", msg);//这里的Show代表是客户端的方法
    15. }
    16. /// <summary>
    17. /// 用户上线就将用户名和连接id绑定
    18. /// </summary>
    19. /// <param name="name"></param>
    20. public void SendLogin(string name)
    21. {
    22. if (!userList.Contains(name))
    23. {
    24. userList.Add(name);
    25. _connections.Add(name, Context.ConnectionId);
    26. }
    27. else
    28. {
    29. _connections[name] = Context.ConnectionId;
    30. }
    31. }
    32. public override Task OnConnectedAsync()
    33. {
    34. return base.OnConnectedAsync();
    35. }
    36. public async Task AddToGroup(string groupName)
    37. {
    38. await Groups.AddToGroupAsync(Context.ConnectionId, groupName);
    39. await Clients.Group(groupName).SendAsync("ShowMsg", "");
    40. }
    41. public async Task RemoveFromGroup(string groupName)
    42. {
    43. await Groups.RemoveFromGroupAsync(Context.ConnectionId, groupName);
    44. }
    45. }
    46. public class UserInfo
    47. {
    48. public static IList<string> userList = new List<string>();
    49. }
    50. }

    其次在Startup.cs中进行注入和配置,在ConfigureServices中添加如下代码

    1. services.AddCors(opttion => opttion.AddPolicy("cors", policy => policy.SetIsOriginAllowed(_=>true)
    2. .AllowAnyHeader().AllowAnyMethod().AllowCredentials().AllowAnyOrigin()));
    3. //注册SignalR服务
    4. services.AddSignalR();

     最后在Configure中配置相关中间件使用,代码如下

    1. app.UseCors("cors");//跨域
    2. //可以设置SignalR相关参数,这里设置地址
    3. app.UseSignalR(routes => {
    4. routes.MapHub<MsgHub>("/hub");
    5. });

    到此,服务端准备完毕!!!

    Vue 客户端准备(前提条件: 已经通过Vue-cli脚手架工具把项目搭建起来了)

    首先安装对应的signalR插件

    npm i --save@aspnet/signalr’   (或者 cnpm i --save '@microsoft/signalr@^6.0.1')

    其次开始封装js,这里是在utils文件夹下创建了signalR.js文件,内容如下

    1. //引入安装的signalr包
    2. import * as signalR from '@aspnet/signalr'
    3. const signal = new signalR.HubConnectionBuilder()
    4. .withUrl('http://localhost:52970/lchub/signalr', {})//服务器地址
    5. .build()
    6. const signalr = function () {
    7. var hub
    8. if (hub === undefined) {
    9. hub = signal
    10. }
    11. return hub
    12. }
    13. // 自动重连
    14. async function start () {
    15. try {
    16. await signal.start()
    17. console.log('connected')
    18. } catch (err) {
    19. console.log(err)
    20. setTimeout(() => start(), 5000)
    21. }
    22. }
    23. signal.onclose(async () => {
    24. await start()
    25. }) //将创建的signal赋值给Vue实例
    26. export default {
    27. //install方法的第一个参数是 Vue 构造器,第二个参数是一个可选的选项对象。
    28. install: function(Vue) {
    29. Vue.prototype.signalr = signal
    30. }
    31. }

    然后在main.js中全局引入

    1. import signalr from './utils/signalR'
    2. Vue.use(signalr)

    客户准备就完成了,现在就可以使用了,在任意组件中都可以使用,使用方式如下:

    1. //在Vue的生命周期Created函数中注册相关事件
    2. created(){
    3.   //这里Show就是在服务端指定的Show的方法名称,这里是先清除,再加上
    4. this.signalr.off('Show');
    5. this.signalr.on('Show',res=>{
    6. //可以做相关业务逻辑
    7. console.log('signalr 来了');
    8. })
    9. },
    10. //在Vue的生命周期函数mounted中进行连接
    11. mounted () {
    12. this.signalr.start().then(() => {
    13. console.log('连接');
    14. })
    15. }

     完结...

  • 相关阅读:
    简单OpenSL ES学习
    Netty:入门(1)
    Flutter入门教程(一)Flutter简介
    机器人路径规划:基于A*算法的机器人路径规划(提供Python代码)
    Java 后端面试指南
    Python的面向对象编程之—— 类和对象
    STM32中的printf重定向uart1串口输出
    vulfocus——thinkphp3.2.x代码执行
    如何提高网站安全防护?
    React hooks优势
  • 原文地址:https://blog.csdn.net/qq_26695613/article/details/133243492