.netcore signalR 实时消息推送
服务器端引入包 Install-Package Microsoft.AspNetCore.SignalR
客户端引入包 npm install @aspnet/signalr
<template>
<div><p>测试SignalR后台推送消息</p><p>ConnectionId {{connectId}}</p> {{retData}}</div>
</template> <script>
import * as signalR from '@aspnet/signalr'
export default {
data() {
return {
retData: '',
connection: "",
connectId:""
}
},
methods: {
},
created: function () {
let thisVue = this; //1 客户端创建连接
let connection = new signalR.HubConnectionBuilder()
.withUrl('/api/chathub')
//.withUrl('/chathub',signalR.HttpTransportType.WebSockets)//手动指定传输方式, 请在withUrl()方法的第二个参数
.build(); //2 监听服务器端发送的方法
connection.on('someFunc', function (obj) {
thisVue.retData =obj.radom ;
});
connection.on('receiveupdate', function (obj) {
thisVue.retData =obj ;
});
connection.on('getconnectId', function (obj) {
thisVue.connectId = obj.connectId
});
connection.on('finsied', function () {
connection.stop();
thisVue.retData = "finished"
}); //3 开始通信,并调用服务器端方法GetLatestCount
connection.start()
//.then(() => {connection.invoke('GetLatestCount', 1);thisVue.retData = "started"})
.catch(err => console.error(err.toString()));
}
}
</script>
前端代码
startup.cs添加代码
services.AddSignalR(); app.UseSignalR(route =>
{
route.MapHub<ChatHub>("/api/chathub");
});
Startup
写一个Hub中心代码,继承自Hub类
引入包
public class ChatHub : Hub
{
public string connectionId = "";
//客户端调用服务器端的GetLatestCount方法
//服务器端调用客户端的receiveupdate方法(前端监听)
public async Task GetLatestCount(string random)
{
int count = ;
do
{
count++;
Thread.Sleep();
await Clients.All.SendAsync("receiveupdate", random + " " + count);
} while (count < ); await Clients.All.SendAsync("finsied");
} public override async Task OnConnectedAsync()
{
var connectionId = Context.ConnectionId;
//await Groups.AddToGroupAsync(connectionId, "mygroup");
//await Groups.RemoveFromGroupAsync(connectionId, "mygroup");
//await Clients.Group("mygroup").SendAsync("someFunc", new { radom = "0.0" }); await Clients.Client(connectionId).SendAsync("getconnectId", new { connectId = connectionId });
}
}
ChatHub
控制器中模拟触发后端推送请求
[Produces("application/json")]
[Route("api/chat")]
public class ChatHubController : Controller
{
private readonly IHubContext<ChatHub> _hubContext;
public ChatHubController(IHubContext<ChatHub> hubContext)
{
_hubContext = hubContext;
}
//测试消息实时推送
[HttpPost]
public async Task<IActionResult> Post()
{
await _hubContext.Clients.All.SendAsync("someFunc", new { radom = new Random().Next(,)});
return Ok();// Accepted(1);//202 请求已接收并处理,但还没有处理完成
}
}
ChatHubController


.netcore signalR 实时消息推送的更多相关文章
- WebForm SignalR 实时消息推送
原文:https://www.jianshu.com/p/ae25d0d77011 官方文档:https://docs.microsoft.com/zh-cn/aspnet/signalr/ 实现效果 ...
- 基于SignalR的消息推送与二维码描登录实现
1 概要说明 使用微信扫描登录相信大家都不会陌生吧,二维码与手机结合产生了不同应用场景,基于二维码的应用更是比较广泛.为了满足ios.android客户端与web短信平台的结合,特开发了基于Singl ...
- AngularJS+ASP.NET MVC+SignalR实现消息推送
原文:AngularJS+ASP.NET MVC+SignalR实现消息推送 背景 OA管理系统中,员工提交申请单,消息实时通知到相关人员及时进行审批,审批之后将结果推送给用户. 技术选择 最开始发现 ...
- Signalr实现消息推送
一.前言 大多数系统里面好像都有获取消息的功能,但这些消息来源都不是实时的,比如你开两个浏览器,用两个不同的账号登录,用一个账号给另外一个账号发送消息,然而并不会实时收到消息,必须要自己手动F5刷新一 ...
- 开源实时消息推送系统 MPush
系统介绍 mpush,是一款开源的实时消息推送系统,采用java语言开发,服务端采用模块化设计,具有协议简洁,传输安全,接口流畅,实时高效,扩展性强,可配置化,部署方便,监控完善等特点.同时也是少有的 ...
- 基于socket.io的实时消息推送
用户访问Web站点的过程是基于HTTP协议的,而HTTP协议的工作模式是:请求-响应,客户端发出访问请求,服务器端以资源数据响应请求. 也就是说,服务器端始终是被动的,即使服务器端的资源数据发生变化, ...
- Worktile中百万级实时消息推送服务的实现
Worktile中百万级实时消息推送服务的实现 出自:http://blog.jobbole.com/81125/
- 【js学习】js连接RabbitMQ达到实时消息推送
js连接RabbitMQ达到实时消息推送 最近在自己捯饬一个网站,有一个功能是需要后端处理完数据把数据发布到MQ中,前端再从MQ中接收数据.但是前端连接MQ又成了一个问题,在网上搜了下资料,点进去一篇 ...
- 未读消息(小红点),前端与 RabbitMQ实时消息推送实践,贼简单~
前几天粉丝群里有个小伙伴问过:web 页面的未读消息(小红点)怎么实现比较简单,刚好本周手头有类似的开发任务,索性就整理出来供小伙伴们参考,没准哪天就能用得上呢. 之前在 <springboot ...
随机推荐
- BZOJ3998 TJOI2015弦论(后缀自动机)
先考虑相同子串视为一个.按SAM的拓扑序预处理出从每个节点开始能得到多少个本质不同子串(注意虽然一个节点对应多个子串,但到达该点时当前的子串显然是确定为其中一个的),然后按位贪心即可. 相同子串视为多 ...
- (十七)Activitivi5之组任务分配
一.需求分析 我们在实际业务开发过程中,某一个审批任务节点可以分配一个角色(或者叫做组),然后属于这个角色的任何一个用户都可以去完成这个任务节点的审批 二.案例 2.1 方式一:直接流程图配置中写死 ...
- Python练习_集合和深浅拷贝_day7
1. 1.作业 1.把列表中所有姓周的人的信息删掉(升级题:此题有坑, 请慎重): lst = ['周老二', '周星星', '麻花藤', '周扒皮'] 结果: lst = ['麻花藤'] 2.车牌区 ...
- restTemplate源码解析(一)构造restTemplate的Bean实例
所有文章 https://www.cnblogs.com/lay2017/p/11740855.html 正文 构造一个restTemplate的Bean实例很容易,只需这样配置 @Bean publ ...
- js检测是不是数字
function isValueNumber(value) { var reg = (/(^-?[0-9]+\.{1}\d+$)|(^-?[1-9][0-9]*$)|(^-?0{1}$)/); var ...
- C++线程同步之原子操作
所谓的原子操作就是指一个线程对于某一个资源做操作的时候能够保证没有其它的线程能够对此资源进行访问. 原子操作仅仅能够解决某一个变量的问题,只能使得一个整型数据做简单算术运算的时候是原子的. 以下案例需 ...
- 解决yum命令后出现libldap-2.4.so.2: cannot open shared object file
问题: [root@lgh ~]# yum There was a problem importing one of the Python modules required to run yum. T ...
- 基于OPENldap搭建postfix 虚拟用户
本文首发: https://www.somata.work/2019/DependOPENldapBuildPostfixVirtualMailUser.html postfix + dovecot ...
- Kubernetes的核心技术概念和API对象
Kubernetes的核心技术概念和API对象 API对象是K8s集群中的管理操作单元.K8s集群系统每支持一项新功能,引入一项新技术,一定会新引入对应的API对象,支持对该功能的管理操作.例如副本集 ...
- 禁止html页面返回上一层
两种方式: // 方式一 触发返回上一层页面事件,只会重新加载当前页面 window.addEventListener('pageshow', function(e) { if (e.persiste ...