.net后端使用SignalR定时向前端vue推送消息
admin
2024-02-28 05:09:47
0

SignalR

SignalR 是一个 .NET Core/.NET Framework 的开源实时框架,可以使用 Web Socket、Server Sent Events 和 Long Polling 作为底层传输方式,包含服务端和客户端。

Web Socket 是最高效的传输方式,不过仅支持比较现代的浏览器,如果浏览器或 Web 服务器不支持它的话,就会降级使用 Server Sent Events,实在不行就用 Long Polling。

为什么需要 WebSocket

HTTP 协议:通信只能是客户端发起,做不到服务器主动向客户端推送信息。

Websocket 就是在这样的环境下发明的,想具体了解 WebSocket 可以参考:http://www.ruanyifeng.com/blog/2017/05/websocket.html。

实际应用

1. 服务端

Hub 是 SignalR 的一个组件,它运行在 ASP.NET Core 应用里,所以它是服务器端的一个类。Hub 使用 RPC 接受从客户端发来的消息,也能把消息发送给客户端,所以它就是一个通信用的 Hub。

在 ASP.NET Core 里,自己创建的 Hub 类需要继承于基类Hub,在 Hub 类里面,我们就可以调用所有客户端上的方法了,同样客户端也可以调用 Hub 类里的方法。下面看一下代码:

IChatClient.cs

using System.Threading.Tasks;namespace SignalRServerAndVueClient.Hubs
{/// /// https://docs.microsoft.com/zh-cn/aspnet/core/signalr/hubs?view=aspnetcore-3.1/// 强类型中心/// public interface IChatClient{Task ReceiveMessage(string user, string message);Task ReceiveMessage(object message);Task ReceiveCaller(object message);}
}

ChatHub.cs

using System;
using System.Threading.Tasks;
using Microsoft.AspNetCore.SignalR;namespace SignalRServerAndVueClient.Hubs
{public class ChatHub : Hub{/// /// 给所有客户端发送消息/// /// 用户/// 消息/// public async Task SendMessage(string user, string message){await Clients.All.ReceiveMessage(user, message);}/// /// 向调用客户端发送消息/// /// /// public async Task SendMessageCaller(string message){await Clients.Caller.ReceiveCaller( message);}/// /// 客户端连接服务端/// /// public override Task OnConnectedAsync(){var id = Context.ConnectionId;//_logger.Info($"客户端ConnectionId=>【{id}】已连接服务器!");return base.OnConnectedAsync();}/// /// 客户端断开连接/// /// /// public override Task OnDisconnectedAsync(Exception exception){var id = Context.ConnectionId;//_logger.Info($"客户端ConnectionId=>【{id}】已断开服务器连接!");return base.OnDisconnectedAsync(exception);}}}

在 Startup.cs 的 Configure 中添加如下代码:

app.UseEndpoints(endpoints =>
{endpoints.MapControllers();endpoints.MapHub("/chathub");
});

注册 SignalR。

再来看一下定时任务。代码实现如下:

HubsQuartzService.cs

using System;
using Quartz;
using System.Threading;
using System.Threading.Tasks;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;namespace SF.BLL.HostedService
{   /// ///定时任务/// public class HubsQuartzService : IHostedService, IDisposable{private readonly ILogger _logger;private IScheduler _scheduler;/// /// 定时调用任务接口/// //private ITbBackUpInfoInterface interfaceObj;/// ///构造函数/// public HubsQuartzService(ILogger logger, IScheduler scheduler){_logger = logger;_scheduler = scheduler;}/// ///启动定时/// public Task StartAsync(CancellationToken cancellationToken){_logger.LogInformation("启动定时job");IJobDetail jobDetail = JobBuilder.Create().WithIdentity("定时消息推送").Build();ITrigger trigger = TriggerBuilder.Create().WithCronSchedule($"*/10 * * * * ?").WithIdentity("定时确认").StartNow().Build();_scheduler.ScheduleJob(jobDetail, trigger);_scheduler.Start();return Task.CompletedTask;}/// ///结束定时/// public Task StopAsync(CancellationToken cancellationToken){_scheduler.Shutdown();_logger.LogInformation("关闭定时job");return Task.CompletedTask;}/// ///排列/// public void Dispose(){}}
}

MyJob.cs

public class MyJob : IJob
{private readonly IHubContext _hubContext;public MyJob(IHubContext hubContext){_hubContext = hubContext;}public Task Execute(IJobExecutionContext context){await _hubContext.Clients.All.SendAsync("ReceiveMessage", "系统通知", $"最新消息{DateTime.Now}");}
}

在 Startup.cs 的 configureservices 添加如下代码:

services.AddHostedService();

2. 客户端

首先安装:npm install @microsoft/signalr

然后导入:

import * as signalR from "@aspnet/signalr";

之后在 created 中添加如下代码:

created() {let thisVue = this;this.connection = new signalR.HubConnectionBuilder().withUrl("http://localhost:52789/chathub", {skipNegotiation: true,transport: signalR.HttpTransportType.WebSockets,}).configureLogging(signalR.LogLevel.Information).build();this.connection.on("ReceiveMessage", function (user, message) {thisVue.messages.push({ user, message });thisVue.msg = message;thisVue.$alert(message, '提示', {confirmButtonText: '确定',// eslint-disable-next-line no-unused-varscallback: action => {/*this.$message({type: 'info',message: `action: ${ action }`});*/}});});this.connection.start();},

上一篇:Redis 哈希( Hash )

下一篇:PHP redis hash

相关内容

热门资讯

海南自贸港“样板间”抢抓开放机... 中新网海口5月16日电 (记者 王子谦)洋浦经济开发区是海南自贸港“样板间”,也是外界观察自贸港建设...
净利增速2.98%,违规频发!... 近期,中信银行2025年年报与2026年一季报接连公布,报告显示,中信银行总资产站稳10万亿元台阶,...
原创 放... 全网的人几乎都在挤破头往海外大都市扎,可有一个女博主,却偏偏反着来。她拥有五百多万粉丝,本可以继续在...
原创 在... 在中国,买卖虚拟货币,到底行不行? 这个问题,很多人心里都犯嘀咕。有人说,法无禁止即可为;也有人说,...
龙粤慈善事业高质量发展与互联网... 近日,为加快培育数字慈善新生态,助力“善行边疆”活动走深走实,“龙粤慈善事业高质量发展与互联网公开募...
黄金大局已定:不出意外的话,2... 在投资领域,贵金属一直是备受关注的资产类别,尤其是黄金,其价格走势和投资价值牵动着无数投资者的心。随...
后巴菲特时代,伯克希尔哈撒韦新... 【导读】伯克希尔哈撒韦最新持仓公布!清仓亚马逊,建仓达美航空 中国基金报记者 张舟 伯克希尔哈撒韦“...
布朗46分胡金秋20+8 广厦... 【搜狐体育战报】北京时间5月16日CBA季后赛,主场作战的浙江浙商证券以111-102击败深圳马可波...
美联储任命鲍威尔担任临时主席 美国联邦储备委员会理事会5月15日发布公告,任命杰罗姆·鲍威尔担任美联储临时主席,直至凯文·沃什宣誓...
李从悠:白癜风患者,夏季防汗疹... 夏季高温多雨,白癜风患者皮肤屏障受损,出汗后汗液无法及时蒸发,易堵塞毛孔,诱发汗疹(热疹),汗疹引发...
最低涨价60元!4款非标茅台酒... 在飞天茅台涨价之后,部分非标茅台酒也提了价。 5月16日早间,贵州茅台自营渠道i茅台发布公告,宣布对...
邯郸10亿共享智造基金落地,撬... 图片为AI生成 据天眼查App显示,近日邯郸市共享智造股权投资基金(有限合伙)正式登记成立,总出资额...
AI制药行业深度:行业概况、市... 一、AI制药行业概况 1、AI药物研发概述 AI制药是指将NLP、深度神经网络,生成模型等AI技...
世界杯在即:国产彩电的出海故事... 球还没看,彩电先破防了 撰文/ 孟会缘 编辑/ 陈邓新 排版/ Annalee 国产彩电品牌,正深陷...
医疗健康领域投融资日报(5月1... 据亿欧数据统计,昨日(2026年5月15日)共披露16起投融资事件,涉及15家国内企业,1家国外企业...
深圳中创商业咨询携手海旗控股集... 海旗控股集团旗下宁波锦曼程新材料有限公司,自创立以来始终深耕高分子材料领域,秉承推动行业创新与可持续...
原创 关... 前言 大家好,我是老金。 国际地缘博弈的棋盘上,从来没有绝对的秘密,只有刻意或无意的战略试探,近期...
原创 欧... 今天来给大家聊一下最近的欧盟,自从特朗普说要来访华,欧洲的动作有点让人看不懂。从四月中旬到五月初,欧...
心系投资者 携手共行动 ——人... 为落实监管工作要求,切实维护金融消费者合法权益,在 “5・15 全国投资者保护宣传日” 当天,人保寿...
黄仁勋打卡蜜雪冰城 同款产品销... 财联社5月16日讯(记者 沈娇娇)5月15日上午,英伟达CEO黄仁勋现身北京南锣鼓巷,并且进入一家蜜...