用SignaiR和Push.js完成訊息推送代碼詳解

來源:互聯網
上載者:User
ASP.NET SignalR 是為 ASP.NET 開發人員提供的一個庫,可以簡化開發人員將即時 Web 功能添加到應用程式的過程。有興趣的可以瞭解一下。

一.使用背景

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基礎視頻教程

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.