.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

相关内容

热门资讯

别再骂孩子“笨”!学习困难不是... “同样的知识点,别人听一遍就会,你怎么教都不会”“作业磨磨蹭蹭,简单的题也总出错”“明明很努力,成绩...
通辽年货节:消费盛宴燃动冬日,... “这个牛肉干味道超棒,奶茶香得不得了!”“年货都快置办齐全啦!”“用卡消费能凑满减,太划算了!”1月...
黄金白银价格剧烈波动,豫光金铅... 【大河财立方消息】现货黄金和白银价格近期在刷新历史高点后出现大幅波动,2月2日再度跳水。截至发稿,现...
AI眼镜能把Meta从元宇宙的... 出品|虎嗅科技组 作者|赵致格 编辑|苗正卿 头图|视觉中国 “我们的AI眼镜正在重塑人们体验世界的...
马上评|上海定制消费,凭啥吸引... 近期,上海的定制消费引发热议:南外滩轻纺面料市场,众多中外消费者排队定制西装、旗袍、中式礼服,多种语...
黄金暴跌,市场总有轮回。 今天不聊别的,还是聊黄金。但今天为了说清楚黄金,我会先分析同样经历了暴跌的比特币、以太坊等crypt...
2025年净利最高预亏2.9亿... 北京商报讯(记者 丁宁)2月2日,双鹭药业(002038)盘中触及跌停,截至北京商报记者发稿,双鹭药...
盘点2025信托业(二)|新监... 中国网财经2月2日讯 2025年,信托行业监管制度体系经历根本性重塑,“1+N”政策框架落地生根,为...
中国国航2026年春运计划执行... 中国国际航空股份有限公司(下称“国航”)2月2日宣布,2026年春运将全面升级运力投入,在册飞机数量...
原创 今... 一家公司,在不到一个月的时间里,股价像坐上了火箭,一口气连拉17个涨停板,价格翻了4倍多。 就在所有...
脑出血后昏迷不醒有什么治疗方法... 脑出血是一种发病急、进展快、致死致残率极高的急性脑血管疾病,其发病率约占全部脑卒中的20%~30%,...
原创 今... 今天A股跌得让人心慌,商业航天、黄金、农业,热点一个接一个熄火。 但在一片惨绿中,有一个板块却像打了...
2026年存款搬家,有望为A股... 根据财通证券测算,2026年企业与居民中长期存款的到期规模在57.3万亿元,而居民中长期存款到期规模...
两部门发文明确增值税进项税额抵... 财政部 税务总局 关于增值税进项税额抵扣等有关事项的公告 财政部 税务总局公告2026年第13号 根...
兴业银行多位经理被禁止从事银行... 据国家金融监督管理总局大连监管局2月2日公开的行政处罚信息显示,兴业银行股份有限公司大连分行因信贷业...
原创 金... 深圳水贝市场里,一位女士快速计算着价格,掏出银行卡支付了近12万元,买下100克金条。 黄金价格正在...
韩国股市大跌触发熔断机制 1日,韩国首尔,中区一家银行交易室的电子屏显示韩国综合股价指数(KOSPI)。视觉中国/图 韩国股市...
尿色加深、皮肤泛黄时,你的肝可... 生活中,不少人发现尿色变深、皮肤泛黄时,会误以为是喝水少、上火或肤色问题,简单调整后便不再关注。可这...
30亿元红包!千问宣布 2月2日,千问APP宣布投入30亿元启动“春节请客计划”,以免单形式请全国人民在春节期间吃喝玩乐,感...
周生生足金挂坠被检测出含铁银钯... 编者按:维护消费者权益,守护消费安全。央广网啄木鸟消费者投诉平台,保障消费者合法权益,为新消费时代保...