一.使用背景

1. SignalR是什么?
ASP.NET SignalR 是为 ASP.NET 开发人员提供的一个库,可以简化开发人员将实时 Web 功能添加到应用程序的过程。实时 Web 功能是指这样一种功能:当所连接的客户端变得可用时服务器代码可以立即向其推送内容,而不是让服务器等待客户端请求新的数据。
2.Push.js是什么?【需要浏览器支持H5Notifications】
Notifications翻译过来即是通知。那么Push.js的通知又是什么样的,见下图:大多数在屏幕的右下角出现。
需要允许哦:
3.很多时候我们只能使用轮询的方式进行数据展示的更新和消息推送。于是就想到有没有一种方式可以完成服务端数据更新时同步更新客户端的一种解决方案。
二.开始部署一个 SignalR项目【使用mvc】
1.新建mvc项目
.....................
2.导入程序包【Vs2015】
工具->NuGet包管理器-> 程序包管理控制台->Install-Package Microsoft.AspNet.SignalR->等待安装成功
3.新建集线器类
项目->右键->添加->新建项->SignalR->SignalR 永久链接类->保存->【以MyConnection1为例】MyConnection1
public class MyConnection1 : PersistentConnection
{
/// <summary>
/// 发送消息
/// </summary>
/// <param name="request"></param>
/// <param name="connectionId"></param>
/// <returns></returns>
protected override Task OnConnected(IRequest request, string connectionId)
{
Debug.WriteLine(connectionId);
return Connection.Send(connectionId, "Welcome!");//单推事列
}
/// <summary>
/// 接受客户端消息
/// </summary>
/// <param name="request"></param>
/// <param name="connectionId"></param>
/// <param name="data"></param>
/// <returns></returns>
protected override Task OnReceived(IRequest request, string connectionId, string data)
{
Debug.WriteLine(data);
return Connection.Broadcast(data);//广播
}
/// <summary>
/// 掉线
/// </summary>
/// <param name="request"></param>
/// <param name="connectionId"></param>
/// <param name="stopCalled"></param>
/// <returns></returns>
protected override Task OnDisconnected(IRequest request, string connectionId, bool stopCalled)
{
Debug.WriteLine("掉线");
return base.OnDisconnected(request, connectionId, stopCalled);
}
/// <summary>
/// 重连
/// </summary>
/// <param name="request"></param>
/// <param name="connectionId"></param>
/// <returns></returns>
protected override Task OnReconnected(IRequest request, string connectionId)
{
Debug.WriteLine("重连");
return base.OnReconnected(request, connectionId);
}
}
4.新建 Owin Startup 类【SignalR遵循Owin标准,Startup则是组件的启动,默认会存在Startup类,只需修改即可】
我们在Configuration里面追加以下代码
public void Configuration(IAppBuilder app)
{
app.MapSignalR<MyConnection1>("/myconnection");
}
解释:访问myconnection的时候,触发MyConnection1
5.增加客户端【h5】
@{
ViewBag.Title = "Home Page";
Layout = null;
}
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<meta charset="utf-8" />
</head>
<body>
<script src="~/Scripts/jquery-1.10.2.js"></script>
<script src="~/Scripts/jquery.signalR-2.2.1.js"></script>
<script type="text/javascript">
var conn = $.connection("/myconnection");
conn.start().done(function (data) {
console.log("已连接服务器,当前GUID为" + data.id);
conn.send("To Admin");//发送给服务器
});
//接受服务器的推送
conn.received(function (data) {
console.log("服务器返回消息: " + data);
});
</script>
</body>
</html>
6.启动项目 打开浏览器控制台,你会发现见下图、这就表示你已经完成了第一步。
7.下面我们需要准备 push.js
下载地址 https://github.com/Nickersoft/push.js
8.引用js
<script src="../Js/push.js"></script>
9.新建js推送demo
function push(data, url, img) {
var imgurl = img != "" ? img : "../Images/icon.png";
Push.create("新通知", {
body: data,
icon: imgurl,
requireInteraction: true,
onClick: function () {
window.focus();
this.close();
window.location.href =url;
}
});
}
解释:data:为消息内容
url:为点击通知进入的链接
img: 为通知展示的图片地址
requireInteraction: 设置为true时,除非用户手动关闭或单击该通知,否则该通知不会关闭。需要设置消失时间请替换该属性为timeout: 5000 单位毫秒
其他事件请阅读:https://www.npmjs.com/package/push.js
10.组合两者
//实时推送
var conn = $.connection("/myconnection");
conn.start().done(function (data) {
console.log("已连接服务器,当前GUID为" + data.id);
});
//接受服务器的推送
conn.received(function (msg) {
console.log("服务器返回消息: " + msg);
if (msg != "") {
push(msg, "#", "")
}
});
11.效果如下:
12.实现服务器的主动推送.现只介绍广播。单推原理一致。
分为广播及单推两种模式。
广播:
var context = GlobalHost.ConnectionManager.GetConnectionContext<MyConnection1>();//获取你当前的Connection连接
context.Connection.Broadcast("我是一条新的推送消息!");//广播推送
单推:
var context = GlobalHost.ConnectionManager.GetConnectionContext<MyConnection1>();//获取你当前的Connection连接 context.Connection.Send(connectionId, "Welcome!");//单推事列
connectionId:是服务端为每个客户端分配的GUID
13.效果如下:
这样当我们服务端处理某个任务时就可以调用广播来实现主动推送到客户端,进行数据的即时更新及消息的推送。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# ASP.NET实现消息推送
# Signair推送即时消息
# Signalr实现消息推送
# Node.js学习教程之HTTP/2服务器推送【译】
# vue使用stompjs实现mqtt消息推送通知
# Node.js实现数据推送
# JavaScript数据推送Comet技术详解
# 使用 Javascript 实现浏览器推送提醒功能的示例
# 客户端
# 服务端
# 新和
# 开发人员
# 掉线
# 我是
# 程序包
# 又是
# 下载地址
# 则是
# 是指
# 两种
# 只需
# 右键
# 这就
# 为例
# 时就
# 你已经
# 当我们
# 管理器
相关文章:
简易网站制作视频教程,使用记事本编写一个简单的网页html文件?
安徽网站建设与外贸建站服务专业定制方案
教程网站设计制作软件,怎么创建自己的一个网站?
建站之星3.0如何解决常见操作问题?
如何选择高效便捷的WAP商城建站系统?
沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?
太平洋网站制作公司,网络用语太平洋是什么意思?
建站之星在线版空间:自助建站+智能模板一键生成方案
北京网站制作网页,网站升级改版需要多久?
网站制作企业,网站的banner和导航栏是指什么?
nginx修改上传文件大小限制的方法
如何快速搭建高效可靠的建站解决方案?
如何快速查询网址的建站时间与历史轨迹?
较简单的网站制作软件有哪些,手机版网页制作用什么软件?
名字制作网站免费,所有小说网站的名字?
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
微网站制作教程,我微信里的网站怎么才能复制到浏览器里?
上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?
如何选择适合PHP云建站的开源框架?
h5在线制作网站电脑版下载,h5网页制作软件?
宿州网站制作公司兴策,安徽省低保查询网站?
如何选择网络建站服务器?高效建站必看指南
淘宝制作网站有哪些,淘宝网官网主页?
,怎么用自己头像做动态表情包?
台州网站建设制作公司,浙江手机无犯罪记录证明怎么开?
单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?
Android使用GridView实现日历的简单功能
魔毅自助建站系统:模板定制与SEO优化一键生成指南
建站之星展会模版如何一键下载生成?
浅谈Javascript中的Label语句
制作网站的模板软件,网站怎么建设?
如何正确选择百度移动适配建站域名?
如何快速搭建高效服务器建站系统?
网站设计制作公司地址,网站建设比较好的公司都有哪些?
建站之家VIP精选网站模板与SEO优化教程整合指南
阿里云网站制作公司,阿里云快速搭建网站好用吗?
小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?
江苏网站制作公司有哪些,江苏书法考级官方网站?
,柠檬视频怎样兑换vip?
上海网站制作开发公司,上海买房比较好的网站有哪些?
建站上传速度慢?如何优化加速网站加载效率?
香港服务器选型指南:免备案配置与高效建站方案解析
如何高效搭建专业期货交易平台网站?
c# F# 的 MailboxProcessor 和 C# 的 Actor 模型
如何在IIS中配置站点IP、端口及主机头?
建站之星好吗?新手能否轻松上手建站?
零基础网站服务器架设实战:轻量应用与域名解析配置指南
想学网站制作怎么学,建立一个网站要花费多少?
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
*请认真填写需求信息,我们会在24小时内与您取得联系。