溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Asp.net中SignalR怎么用

發(fā)布時(shí)間:2021-09-09 09:18:17 來(lái)源:億速云 閱讀:149 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章將為大家詳細(xì)講解有關(guān)Asp.net中SignalR怎么用,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

巡更項(xiàng)目中,需要發(fā)送實(shí)時(shí)消息,以及需要任務(wù)開(kāi)始提醒,于是便有機(jī)會(huì)接觸到SignalR,在使用過(guò)程中,發(fā)現(xiàn)用SignalR實(shí)現(xiàn)通信非常簡(jiǎn)單,下面我思明將從三個(gè)方面分享一下:

一、SignalR是什么

Asp.net SignalR是微軟為實(shí)現(xiàn)實(shí)時(shí)通信的一個(gè)類庫(kù)。一般情況下,SignalR會(huì)使用JavaScript的長(zhǎng)輪詢(long polling)的方式來(lái)實(shí)現(xiàn)客戶端和服務(wù)器通信,隨著Html5中WebSockets出現(xiàn),SignalR也支持WebSockets通信。另外SignalR開(kāi)發(fā)的程序不僅僅限制于宿主在IIS中,也可以宿主在任何應(yīng)用程序,包括控制臺(tái),客戶端程序和Windows服務(wù)等,另外還支持Mono,這意味著它可以實(shí)現(xiàn)跨平臺(tái)部署在Linux環(huán)境下。

SignalR內(nèi)部有兩類對(duì)象:

Http持久連接(Persisten Connection)對(duì)象:用來(lái)解決長(zhǎng)時(shí)間連接的功能。還可以由客戶端主動(dòng)向服務(wù)器要求數(shù)據(jù),而服務(wù)器端不需要實(shí)現(xiàn)太多細(xì)節(jié),只需要處理PersistentConnection 內(nèi)所提供的五個(gè)事件:OnConnected, OnReconnected, OnReceived, OnError 和 OnDisconnect 即可。

Hub(集線器)對(duì)象:用來(lái)解決實(shí)時(shí)(realtime)信息交換的功能,服務(wù)端可以利用URL來(lái)注冊(cè)一個(gè)或多個(gè)Hub,只要連接到這個(gè)Hub,就能與所有的客戶端共享發(fā)送到服務(wù)器上的信息,同時(shí)服務(wù)端可以調(diào)用客戶端的腳本。

SignalR將整個(gè)信息的交換封裝起來(lái),客戶端和服務(wù)器都是使用JSON來(lái)溝通的,在服務(wù)端聲明的所有Hub信息,都會(huì)生成JavaScript輸出到客戶端,.NET則依賴Proxy來(lái)生成代理對(duì)象,而Proxy的內(nèi)部則是將JSON轉(zhuǎn)換成對(duì)象。

二、為什么要用SignalR

聊天室,如在線客服系統(tǒng),IM系統(tǒng)等

消息的實(shí)時(shí)推送服務(wù)

巡更人員位置的實(shí)時(shí)推送

三、怎么實(shí)現(xiàn)SignalR,下面主要介紹一下SignalR第一大功能,聊天。以下是一個(gè)簡(jiǎn)單的DEMO:

1、新建一個(gè)asp.net web 應(yīng)用程序

Asp.net中SignalR怎么用

2、選擇模板MVC,同時(shí)更改無(wú)身份驗(yàn)證

Asp.net中SignalR怎么用

3、選擇新建的項(xiàng)目,右擊-->選擇管理NuGet程序包-->搜索 signalr--> 安裝Microsoft ASP.NET SignalR

Asp.net中SignalR怎么用

4、新建啟動(dòng)程序 Startup.cs

Asp.net中SignalR怎么用

在類中添加代碼:

app.MapSignalR();

Asp.net中SignalR怎么用

5、新建SignalR集線器類ChatHub.cs

Asp.net中SignalR怎么用

6、在集線器類ChatHub.cs中添加如下代碼

public class ChatHub : Hub
 {
  /// <summary>
  /// 供客戶端調(diào)用的服務(wù)器端代碼
  /// </summary>
  /// <param name="message"></param>
  public void Send(string message)
  {
   var name = Guid.NewGuid().ToString().ToUpper();
   // 調(diào)用所有客戶端的sendMessage方法
   Clients.All.sendMessage(name, message);
  }

  /// <summary>
  /// 客戶端連接的時(shí)候調(diào)用
  /// </summary>
  /// <returns></returns>
  public override Task OnConnected()
  {
   Trace.WriteLine("客戶端連接成功");
   return base.OnConnected();
  }
 }

7、修改Index.cshtml頁(yè)面代碼

@{
 ViewBag.Title = "聊天窗口";
}

<h3>Chat</h3>

<div class="container">
 <input type="text" id="message" />
 <input type="button" id="sendmessage" value="Send" />
 <input type="hidden" id="displayname" />
 <ul id="discussion"></ul>
</div>

@section scripts
{
 <!--引用SignalR庫(kù). -->
 <script src="~/Scripts/jquery.signalR-2.2.2.min.js"></script>
 <!--引用自動(dòng)生成的SignalR 集線器(Hub)腳本.在運(yùn)行的時(shí)候在瀏覽器的Source下可看到 -->
 <script src="~/signalr/hubs"></script>

 <script>
  $(function () {
   // 1、引用自動(dòng)生成的集線器代理 必須用小寫字母開(kāi)頭
   var chat = $.connection.chatHub;

   // 2、開(kāi)始連接服務(wù)器 done函數(shù)表明建立連接成功后為發(fā)送按鈕注冊(cè)了一個(gè)click事件
   $.connection.hub.start().done(function () {
    $('#sendmessage').click(function () {
     // 調(diào)用服務(wù)器端集線器的Send方法 也要小寫開(kāi)頭
     chat.server.send($('#message').val());
     // 清空輸入框信息并獲取焦點(diǎn)
     $('#message').val('').focus();
    });
   });

   // 3、定義服務(wù)器端調(diào)用的客戶端sendMessage來(lái)顯示新消息
   chat.client.sendMessage = function (name, message) {
    // 向頁(yè)面添加消息
    $('#discussion').append('<li><strong>' + htmlEncode(name)
     + '</strong>: ' + htmlEncode(message) + '</li>');
   };

   // 設(shè)置焦點(diǎn)到輸入框
   $('#message').focus();
  });

  // 為顯示的消息進(jìn)行Html編碼
  function htmlEncode(value) {
   var encodedValue = $('<div />').text(value).html();
   return encodedValue;
  }
 </script>
}

8、直接運(yùn)行程序,打開(kāi)多個(gè)網(wǎng)頁(yè),都可以收到相同的消息。。如下:

Asp.net中SignalR怎么用

綜上所述,SignalR使用起來(lái)很方便,而且配置很簡(jiǎn)單,功能也很強(qiáng)大。

關(guān)于“Asp.net中SignalR怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI