欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

asp.net中如何使用SignaiR和Push.js完成消息推送-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)asp.net中如何使用SignaiR和Push.js完成消息推送的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

專注于為中小企業(yè)提供網(wǎng)站制作、網(wǎng)站建設(shè)服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)蔚縣免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了1000多家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。

一.使用背景

1. SignalR是什么?

ASP.NET SignalR 是為 ASP.NET 開發(fā)人員提供的一個庫,可以簡化開發(fā)人員將實時 Web 功能添加到應(yīng)用程序的過程。實時 Web 功能是指這樣一種功能:當(dāng)所連接的客戶端變得可用時服務(wù)器代碼可以立即向其推送內(nèi)容,而不是讓服務(wù)器等待客戶端請求新的數(shù)據(jù)。

2.Push.js是什么?【需要瀏覽器支持H5Notifications】

Notifications翻譯過來即是通知。那么Push.js的通知又是什么樣的,見下圖:大多數(shù)在屏幕的右下角出現(xiàn)。

asp.net中如何使用SignaiR和Push.js完成消息推送

需要允許哦:

asp.net中如何使用SignaiR和Push.js完成消息推送

3.很多時候我們只能使用輪詢的方式進行數(shù)據(jù)展示的更新和消息推送。于是就想到有沒有一種方式可以完成服務(wù)端數(shù)據(jù)更新時同步更新客戶端的一種解決方案。

二.開始部署一個 SignalR項目【使用mvc】

1.新建mvc項目

.....................

2.導(dǎo)入程序包【Vs2015】

工具->NuGet包管理器-> 程序包管理控制臺->Install-Package Microsoft.AspNet.SignalR->等待安裝成功

3.新建集線器類

項目->右鍵->添加->新建項->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則是組件的啟動,默認(rèn)會存在Startup類,只需修改即可】

我們在Configuration里面追加以下代碼

public void Configuration(IAppBuilder app)
    {
      app.MapSignalR<MyConnection1>("/myconnection");
    }

解釋:訪問myconnection的時候,觸發(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.啟動項目 打開瀏覽器控制臺,你會發(fā)現(xiàn)見下圖、這就表示你已經(jīng)完成了第一步。

asp.net中如何使用SignaiR和Push.js完成消息推送

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:為點擊通知進入的鏈接

img: 為通知展示的圖片地址

requireInteraction: 設(shè)置為true時,除非用戶手動關(guān)閉或單擊該通知,否則該通知不會關(guān)閉。需要設(shè)置消失時間請?zhí)鎿Q該屬性為timeout: 5000 單位毫秒

其他事件請閱讀:www.npmjs.com/package/push.js

10.組合兩者

  //實時推送
  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.效果如下:

asp.net中如何使用SignaiR和Push.js完成消息推送

12.實現(xiàn)服務(wù)器的主動推送.現(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ù)端為每個客戶端分配的GUID

asp.net中如何使用SignaiR和Push.js完成消息推送

13.效果如下:

asp.net中如何使用SignaiR和Push.js完成消息推送

這樣當(dāng)我們服務(wù)端處理某個任務(wù)時就可以調(diào)用廣播來實現(xiàn)主動推送到客戶端,進行數(shù)據(jù)的即時更新及消息的推送。

感謝各位的閱讀!關(guān)于“asp.net中如何使用SignaiR和Push.js完成消息推送”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

網(wǎng)站欄目:asp.net中如何使用SignaiR和Push.js完成消息推送-創(chuàng)新互聯(lián)
文章出自:http://aaarwkj.com/article20/dgoojo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護定制開發(fā)、App設(shè)計Google、標(biāo)簽優(yōu)化、網(wǎng)站收錄

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名
麻豆午夜视频免费在线观看| 亚欧成人永久免费视频| 亚洲精品影视一区二区| 色综合亚洲一区二区小说| 国产精品一区二区三区专区| 青青草原在线视频观看| 亚洲不卡在线视频免费| 99热这里有精品久久| 亚洲欧美日韩另类精品一区二区三区| av色狠狠一区二区三区| 亚洲午夜天堂精品福利天堂| 日韩人妻精品中文字幕专区不卡| 亚洲免费一级黄色录像片| 国产精品国产三级国产专用| 成人午夜福利影院在线| 青草草草草草在线观看| 日韩高清一级黄色大片网站| 朝桐光日韩一区二区三区| 国产网红女主播视频一区二区| 欧美久久久久综合一区| av在线男人社区日韩| 中文乱幕亚洲无套内射| 国产精品青青草原在线| 亚洲一区二区视频精品| 黑人巨大精品欧美一区免| 久久精品国产久精国产爱| 亚洲免费一区二区三区精品| 成人国产午夜福利网| 色综合亚洲一区二区小说| 中日中文av一区二区三区| 国产午夜精品福利爽爽| 在线观看男人的天堂av| 久久最新最热视频精品| 国产精品伊人久久综合网| av中文资源在线观看| 日韩电影网国产精品| 国产一区二区三区自拍| 黄片在线免费观看欧美中文| 毛片成人18毛片免费看| 国产午夜精品一区二区三区| 999久久免费精品国产|