一.运用背景
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
下载地点 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 单元毫秒
其他事宜请浏览: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.结果以下:
如许当我们服务端处置惩罚某个使命时就能够挪用播送来完成主动推送到客户端,举行数据的立即更新及音讯的推送。
【相干引荐】
1. ASP免费视频教程
2. ASP教程
3. 李炎恢ASP基本视频教程
以上就是用SignaiR和Push.js完成音讯推送代码详解的细致内容,更多请关注ki4网别的相干文章!