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

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

服务端即Asp.net Core 程序

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

首先编写自己的Hub  

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

or 

using Microsoft.AspNetCore.SignalR;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;namespace MaintainceSysAPI
{public class MsgHub : Hub{private IList<string> userList = UserInfo.userList;public readonly static Dictionary<string, string> _connections = new Dictionary<string, string>();public Task SendMsg(string msg){return Clients.All.SendAsync("ShowMsg", msg);//这里的Show代表是客户端的方法}/// <summary>/// 用户上线就将用户名和连接id绑定/// </summary>/// <param name="name"></param>public void SendLogin(string name){if (!userList.Contains(name)){userList.Add(name);_connections.Add(name, Context.ConnectionId);}else{_connections[name] = Context.ConnectionId;}}public override Task OnConnectedAsync(){return base.OnConnectedAsync();}public async Task AddToGroup(string groupName){await Groups.AddToGroupAsync(Context.ConnectionId, groupName);await Clients.Group(groupName).SendAsync("ShowMsg", "");}public async Task RemoveFromGroup(string groupName){await Groups.RemoveFromGroupAsync(Context.ConnectionId, groupName);}}public class UserInfo{public static IList<string> userList = new List<string>();}}

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

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

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

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

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

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

首先安装对应的signalR插件

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

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

//引入安装的signalr包
import * as signalR from '@aspnet/signalr'const signal = new signalR.HubConnectionBuilder().withUrl('http://localhost:52970/lchub/signalr', {})//服务器地址.build()const signalr = function () {var hubif (hub === undefined) {hub = signal}return hub} //  自动重连async function start () {try {await signal.start()console.log('connected')} catch (err) {console.log(err)setTimeout(() => start(), 5000)}}signal.onclose(async () => {await start()}) //将创建的signal赋值给Vue实例export default {//install方法的第一个参数是 Vue 构造器,第二个参数是一个可选的选项对象。install: function(Vue) {Vue.prototype.signalr = signal}}

然后在main.js中全局引入

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

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

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

 完结...

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/86609.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【完美解决】GitHub连接超时问题 Recv failure: Connection was reset

问题&#xff1a; 已经开了梯子但是在Idea中使用git&#xff08;GitHub&#xff09;还是连接超时Recv failure: Connection was reset。此时需要让git走代理。 解决方案&#xff1a; 1.对右下角网络点击右键 -> 打开网络和Internet设置 2.代理 -> 查看到地址和端口号…

图像处理之《基于语义对象轮廓自动生成的生成隐写术》论文精读

一、相关知识 首先我们需要了解传统隐写和生成式隐写的基本过程和区别。传统隐写需要选定一幅封面图像&#xff0c;然后使用某种隐写算法比如LSB、PVD、DCT等对像素进行修改将秘密嵌入到封面图像中得到含密图像&#xff0c;通过信道传输后再利用算法的逆过程提出秘密信息。而生…

React中的受控组件(controlled component)和非受控组件(uncontrolled component)

聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ 组件⭐ 写在最后 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 欢迎来到前端入门之旅&#xff01;感兴趣的可以订阅本专栏哦&#xff01;这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们量身打造的。无论你是…

【jmeter】jmeter引用变量,变量值传递失败

最近在用jmeter做接口测试的时候&#xff0c;发现有个变量&#xff0c;参数值一直没有传递进来&#xff0c;导致request的时候&#xff0c;请求体里面一直是${}变量的形式。 后来经过排查发现&#xff0c;是因为我在定义用户变量的时候&#xff0c;在这个now后面多加了一个空格…

ps[001] 初学创建剪切蒙版

前置条件&#xff1a;PS2020版本 技能应用&#xff1a;ps 海报标题和图片结合 1、画布1300*1300像素&#xff0c;altdel设置背景为前景色 2、准备一张绿色的海报&#xff0c;可以百度宫崎骏&#xff0c;找张绿色的图片就可以了 3、拉个文字款&#xff0c;写个SUMMER英文体&a…

《开发实战》17 | 异步处理好用,但非常容易用错

大多数业务项目都是由同步处理、异步处理和定时任务处理三种模式相辅相成实现的。区别于同步处理&#xff0c;异步处理无需同步等待流程处理完毕&#xff0c;因此适用场景主要包括&#xff1a; 服务于主流程的分支流程。比如&#xff0c;在注册流程中&#xff0c;把数据写入数…

Python - flask后端开发笔记

​ Flask入门 有一篇很全面的博客可以参考&#xff1a;Python Flask Web 框架入门 跨域问题处理 from flask_cors import CORS CORS(app,supports_credentialsTrue,origins[url], # 前端url列表 ) 文件发送 from flask import send_from_directory app.route(/download) …

SpringAOP入门案例

package com.elf.spring.aop.aspectj; /*** author 45* version 1.0*/ public interface UsbInterface {public void work(); }package com.elf.spring.aop.aspectj; import org.springframework.stereotype.Component; /*** author 45* version 1.0*/ Component //把Phone对象…

什么是WhatsApp群发,WhatsApp协议,WhatsApp云控

那么WhatsApp群控云控可以做什么呢&#xff1f; 1、获客 自动化引流&#xff0c;强大的可控性&#xff0c;产品快速拓客 2、导流 一键式傻瓜化自动加好友&#xff0c;群发&#xff0c;朋友圈营销 3、群控 一键式拉群好友&#xff0c;建群&#xff0c;进群 …

2w+深度梳理!全网最全NLP面试题总结!

目录 技术交流群 1、命名实体识别常见面试篇2、关系抽取常见面试篇3、事件抽取 常见面试篇4、NLP 预训练算法常见面试篇5、Bert 常见面试篇6、文本分类 常见面试篇7、文本匹配 常见面试篇8、问答系统常见面试篇FAQ 检索式问答系统常见面试篇问答系统工具篇常见面试篇 9、对话系…

【MyBatis】代码生成

FQA 报错&#xff1a;Caused by: java.lang.ClassNotFoundException: com.baomidou.mybatisplus.core.handlers.AnnotationHandler 解决办法 <properties><java.version>1.8</java.version><mybatis-plus>3.5.3.2</mybatis-plus><handlebars…

力扣236 补9.14

做不来&#xff0c;我做中等题基本上都是没有思路&#xff0c;这里需要先遍历祖先节点&#xff0c;那必然用先序遍历&#xff0c;这题还是官方题解容易理解&#xff0c;第二火的题解反而把我弄得脑袋昏昏的。 class Solution { TreeNode ans; public TreeNode lowestCommonAnce…

pwncollege.ReverseEngineering

激情写逆向 5.0 origin [0xC3, 0xC2, 0xDF, 0xC7, 0xC4, 0x00 ] result "" for i in range(5):origin[i] origin [i] ^ 0xB7result chr(origin[i])print(result)5.1 origin [0xa3, 0xb5, 0xb1, 0xb4, 0xa1 ] result "" for i in range(5):origin[i]…

公众号迁移多久可以完成?

公众号账号迁移的作用是什么&#xff1f;只能变更主体吗&#xff1f;长期以来&#xff0c;由于部分公众号在注册时&#xff0c;主体不准确的历史原因&#xff0c;或者公众号主体发生合并、分立或业务调整等现实状况&#xff0c;在公众号登记主体不能对应实际运营人的情况下&…

Kubernetes面试题--“新手小题库”

Kubernetes基础 1. 什么是Kubernetes&#xff08;K8s&#xff09;&#xff1f;它的主要目标是什么&#xff1f; Kubernetes是一个开源的容器编排平台&#xff0c;用于自动化容器的部署、扩展和管理。其主要目标包括&#xff1a; 自动化&#xff1a;Kubernetes旨在自动化应用…

【精品】通用Mapper 批量更新bug解决方案

问题描述 环境&#xff1a;mysql8.xmybatis3.5.13tk.mybatis4.2.3 在使用tk.mybatis做批量更新时&#xff0c;程序会报错&#xff0c;说是执行的SQL语法错误&#xff0c;经研究源代码发现tk.mybatis在实现批量更新时是通过多次执行update语句实现的。这本身就不符合MySQL批量…

并发编程之并发理论篇--内存模型

目录 一、Java内存模型的介绍 二、内存模型抽象结构 三、主内存与工作内存 四、内存间交互操作 五、内存模型三大特性 六、内存屏障 七、先行发生原则 八、代码示例 一、Java内存模型的介绍 线程安全是指在多个线程同时访问同一个对象时&#xff0c;无论线程调度和交替…

Django之视图

一&#xff09;文件与文件夹 当我们设定好一个Djiango项目时&#xff0c;里面会有着view.py等文件&#xff0c;也就是文件的方式&#xff1a; 那么我们在后续增加app等时&#xff0c;view.py等文件会显得较为臃肿&#xff0c;当然也根据个人习惯&#xff0c;这时我们可以使用…

2023-9-23 最大不相交区间数量

题目链接&#xff1a;最大不相交区间数量 #include <iostream> #include <algorithm>using namespace std;const int N 100010;int n;struct Range {int l, r;bool operator< (const Range &W) const {return r < W.r;} }range[N];int main() {cin >…

IDEA最新激 20活23码

人狠话不多 大家好&#xff0c;最近Intelli Idea官方的校验规则进行了更新&#xff0c;之前已经成功激20活23的Idea可能突然无法使用了。 特地从网上整理了最新、最稳定的激20活23码分享给大家&#xff0c;希望可以帮助那些苦苦为寻找Idea激20活23码而劳累的朋友们。 本激23…