這篇文章給大家分享的是有關(guān)asp.net中如何使用SignaiR和Push.js完成消息推送的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
專注于為中小企業(yè)提供網(wǎng)站制作、網(wǎng)站建設(shè)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)蔚縣免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了1000多家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。一.使用背景
1. SignalR是什么?
ASP.NET SignalR 是為 ASP.NET 開(kāi)發(fā)人員提供的一個(gè)庫(kù),可以簡(jiǎn)化開(kāi)發(fā)人員將實(shí)時(shí) Web 功能添加到應(yīng)用程序的過(guò)程。實(shí)時(shí) Web 功能是指這樣一種功能:當(dāng)所連接的客戶端變得可用時(shí)服務(wù)器代碼可以立即向其推送內(nèi)容,而不是讓服務(wù)器等待客戶端請(qǐng)求新的數(shù)據(jù)。
2.Push.js是什么?【需要瀏覽器支持H5Notifications】
Notifications翻譯過(guò)來(lái)即是通知。那么Push.js的通知又是什么樣的,見(jiàn)下圖:大多數(shù)在屏幕的右下角出現(xiàn)。
需要允許哦:
3.很多時(shí)候我們只能使用輪詢的方式進(jìn)行數(shù)據(jù)展示的更新和消息推送。于是就想到有沒(méi)有一種方式可以完成服務(wù)端數(shù)據(jù)更新時(shí)同步更新客戶端的一種解決方案。
二.開(kāi)始部署一個(gè) SignalR項(xiàng)目【使用mvc】
1.新建mvc項(xiàng)目
.....................
2.導(dǎo)入程序包【Vs2015】
工具->NuGet包管理器-> 程序包管理控制臺(tái)->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)會(huì)存在Startup類,只需修改即可】
我們?cè)贑onfiguration里面追加以下代碼
public void Configuration(IAppBuilder app) { app.MapSignalR<MyConnection1>("/myconnection"); }
解釋:訪問(wèn)myconnection的時(shí)候,觸發(fā)MyConnection1
5.增加客戶端【h6】
@{ 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)目 打開(kāi)瀏覽器控制臺(tái),你會(huì)發(fā)現(xiàn)見(jiàn)下圖、這就表示你已經(jīng)完成了第一步。
7.下面我們需要準(zhǔn)備 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:為消息內(nèi)容
url:為點(diǎn)擊通知進(jìn)入的鏈接
img: 為通知展示的圖片地址
requireInteraction: 設(shè)置為true時(shí),除非用戶手動(dòng)關(guān)閉或單擊該通知,否則該通知不會(huì)關(guān)閉。需要設(shè)置消失時(shí)間請(qǐng)?zhí)鎿Q該屬性為timeout: 5000 單位毫秒
其他事件請(qǐng)閱讀: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)用廣播來(lái)實(shí)現(xiàn)主動(dòng)推送到客戶端,進(jìn)行數(shù)據(jù)的即時(shí)更新及消息的推送。
感謝各位的閱讀!關(guān)于“asp.net中如何使用SignaiR和Push.js完成消息推送”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
網(wǎng)站欄目:asp.net中如何使用SignaiR和Push.js完成消息推送-創(chuàng)新互聯(lián)
文章出自:http://bm7419.com/article20/dgoojo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)、定制開(kāi)發(fā)、App設(shè)計(jì)、Google、標(biāo)簽優(yōu)化、網(wǎng)站收錄
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容