ASP.NET SignaiR 實(shí)現(xiàn)消息的即時(shí)推送,并使用Push.js實(shí)現(xiàn)通知的示例代碼
一.使用背景
1. SignalR是什么?
ASP.NET SignalR 是為 ASP.NET 開發(fā)人員提供的一個(gè)庫,可以簡化開發(fā)人員將實(shí)時(shí) Web 功能添加到應(yīng)用程序的過程。實(shí)時(shí) Web 功能是指這樣一種功能:當(dāng)所連接的客戶端變得可用時(shí)服務(wù)器代碼可以立即向其推送內(nèi)容,而不是讓服務(wù)器等待客戶端請求新的數(shù)據(jù)。
2.Push.js是什么?【需要瀏覽器支持H5Notifications】
Notifications翻譯過來即是通知。那么Push.js的通知又是什么樣的,見下圖:大多數(shù)在屏幕的右下角出現(xiàn)。

需要允許哦:

3.很多時(shí)候我們只能使用輪詢的方式進(jìn)行數(shù)據(jù)展示的更新和消息推送。于是就想到有沒有一種方式可以完成服務(wù)端數(shù)據(jù)更新時(shí)同步更新客戶端的一種解決方案。
二.開始部署一個(gè) SignalR項(xiàng)目【使用mvc】
1.新建mvc項(xiàng)目
.....................
2.導(dǎo)入程序包【Vs2015】
工具->NuGet包管理器-> 程序包管理控制臺->Install-Package Microsoft.AspNet.SignalR->等待安裝成功
3.新建集線器類
項(xiàng)目->右鍵->添加->新建項(xiàng)->SignalR->SignalR 永久鏈接類->保存->【以MyConnection1為例】MyConnection1
public class MyConnection1 : PersistentConnection
{
/// <summary>
/// 發(fā)送消息
/// </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標(biāo)準(zhǔn),Startup則是組件的啟動(dòng),默認(rèn)會存在Startup類,只需修改即可】
我們在Configuration里面追加以下代碼
public void Configuration(IAppBuilder app)
{
app.MapSignalR<MyConnection1>("/myconnection");
}
解釋:訪問myconnection的時(shí)候,觸發(fā)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("已連接服務(wù)器,當(dāng)前GUID為" + data.id);
conn.send("To Admin");//發(fā)送給服務(wù)器
});
//接受服務(wù)器的推送
conn.received(function (data) {
console.log("服務(wù)器返回消息: " + data);
});
</script>
</body>
</html>
6.啟動(dòng)項(xiàng)目 打開瀏覽器控制臺,你會發(fā)現(xiàn)見下圖、這就表示你已經(jīng)完成了第一步。

7.下面我們需要準(zhǔn)備 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:為消息內(nèi)容
url:為點(diǎn)擊通知進(jìn)入的鏈接
img: 為通知展示的圖片地址
requireInteraction: 設(shè)置為true時(shí),除非用戶手動(dòng)關(guān)閉或單擊該通知,否則該通知不會關(guān)閉。需要設(shè)置消失時(shí)間請?zhí)鎿Q該屬性為timeout: 5000 單位毫秒
其他事件請閱讀:https://www.npmjs.com/package/push.js
10.組合兩者
//實(shí)時(shí)推送
var conn = $.connection("/myconnection");
conn.start().done(function (data) {
console.log("已連接服務(wù)器,當(dāng)前GUID為" + data.id);
});
//接受服務(wù)器的推送
conn.received(function (msg) {
console.log("服務(wù)器返回消息: " + msg);
if (msg != "") {
push(msg, "#", "")
}
});
11.效果如下:

12.實(shí)現(xiàn)服務(wù)器的主動(dòng)推送.現(xiàn)只介紹廣播。單推原理一致。
分為廣播及單推兩種模式。
廣播:
var context = GlobalHost.ConnectionManager.GetConnectionContext<MyConnection1>();//獲取你當(dāng)前的Connection連接
context.Connection.Broadcast("我是一條新的推送消息!");//廣播推送
單推:
var context = GlobalHost.ConnectionManager.GetConnectionContext<MyConnection1>();//獲取你當(dāng)前的Connection連接 context.Connection.Send(connectionId, "Welcome!");//單推事列
connectionId:是服務(wù)端為每個(gè)客戶端分配的GUID

13.效果如下:

這樣當(dāng)我們服務(wù)端處理某個(gè)任務(wù)時(shí)就可以調(diào)用廣播來實(shí)現(xiàn)主動(dòng)推送到客戶端,進(jìn)行數(shù)據(jù)的即時(shí)更新及消息的推送。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
使用.Net實(shí)現(xiàn)多線程經(jīng)驗(yàn)總結(jié)
這篇文章主要介紹了使用.Net實(shí)現(xiàn)多線程經(jīng)驗(yàn)總結(jié),需要的朋友可以參考下2014-12-12
ynamic LINQ創(chuàng)建高級查詢服務(wù)
這篇文章主要介紹了ynamic LINQ創(chuàng)建高級查詢服務(wù),如何使用Dynamic LINQ輕松實(shí)現(xiàn)更強(qiáng)大的高級查詢服務(wù),下面文章內(nèi)容具有一的的參考價(jià)值,需要的小伙伴可以參考一下2022-03-03
防止在服務(wù)器處理完成之前用戶多次點(diǎn)擊提交按鈕處理代碼
在提交表單時(shí),如果網(wǎng)頁速度過慢或者其他原因,用戶多次提交能導(dǎo)致數(shù)據(jù)的修改,怎么解決這個(gè)問題呢,接下來將為您解決這個(gè)問題,需要的朋友可以了解下2012-12-12
Coolite Cool Study 2 同時(shí)更新多個(gè)Tab
前段時(shí)間有一個(gè)需求是這樣子的——錄入一個(gè)查詢條件, 出來的查詢結(jié)果是多張頁面。不知道有沒朋友遇到這個(gè)問題。 展現(xiàn)的效果大概是這個(gè)樣子2009-05-05
.net 通過URL推送POST數(shù)據(jù)具體實(shí)現(xiàn)
這篇文章主要介紹了.net 通過URL推送POST數(shù)據(jù)具體實(shí)現(xiàn),有需要的朋友可以參考一下2013-12-12

