SignalR的簡單實現消息廣播

来源:https://www.cnblogs.com/JentZhang/archive/2018/07/10/9290117.html
-Advertisement-
Play Games

之前由於一個項目的需要(簡單說一下,一個網頁游戲,裁判的頁面點擊開始按鈕,玩家便可以開始游戲),研究了很久,最終一個同事跟我推薦了SignalR。距離項目結束已經有一段時間了,再來回顧一下SignalR的簡單實現吧。 1.什麼 SignalR? ASP.NET SignalR 是為.NET 開發者提 ...


之前由於一個項目的需要(簡單說一下,一個網頁游戲,裁判的頁面點擊開始按鈕,玩家便可以開始游戲),研究了很久,最終一個同事跟我推薦了SignalR。距離項目結束已經有一段時間了,再來回顧一下SignalR的簡單實現吧。

1.什麼 SignalR?

  ASP.NET SignalR 是為.NET 開發者提供即時通訊Web 應用的類庫。即時通訊Web服務就是伺服器將內容自動推送到已經連接的客戶端,而不是伺服器等待客戶端發起一個新的數據請求。簡單來說,就是實現即時通信的功能,裡面很多的功能都已經封裝好了,只需要配置相關的功能即可,然後通過js實現功能。

2.Singal的代碼實現

  1.首先在VS中創建一個MVC項目

       2.通過NuGet安裝SignalR的包並引用到項目

       

  3.成功安裝後,會在Scripts文件夾下麵添加JS腳本庫

  

  4.向項目中添加一個SignalR集線器(v2)並命名為ServerHub。

  

  5.將如下代碼寫入到剛剛添加的ServerHub類中:

  
 1 using System;
 2 using System.Collections.Generic;
 3 using System.Linq;
 4 using System.Web;
 5 using Microsoft.AspNet.SignalR;
 6 
 7 namespace SignalRDemo
 8 {
 9     public class ServerHub : Hub
10     {
11         private static readonly char[] Constant =
12         {
13             '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
14             'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v',
15             'w', 'x', 'y', 'z',
16             'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V',
17             'W', 'X', 'Y', 'Z'
18         };
19 
20         /// <summary>
21         /// 供客戶端調用的伺服器端代碼
22         /// </summary>
23         /// <param name="message"></param>
24         public void Send(string message)
25         {
26             var name = GenerateRandomName(4);
27 
28             // 調用所有客戶端的sendMessage方法
29             Clients.All.sendMessage(name, message);
30         }
31 
32         /// <summary>
33         /// 產生隨機用戶名函數
34         /// </summary>
35         /// <param name="length">用戶名長度</param>
36         /// <returns></returns>
37         public static string GenerateRandomName(int length)
38         {
39             var newRandom = new System.Text.StringBuilder(62);
40             var rd = new Random();
41             for (var i = 0; i < length; i++)
42             {
43                 newRandom.Append(Constant[rd.Next(62)]);
44             }
45             return newRandom.ToString();
46         }
47     }
48 }
View Code

  6.將如下代碼覆蓋原有的Startup的類中:

  
 1 using Microsoft.Owin;
 2 using Owin;
 3 
 4 [assembly: OwinStartupAttribute(typeof(SignalRDemo.Startup))]
 5 namespace SignalRDemo
 6 {
 7     public partial class Startup
 8     {
 9         #region MyRegion
10         public void Configuration(IAppBuilder app)
11         {
12             app.MapSignalR();
13             ConfigureAuth(app);
14         }
15         #endregion
16     }
17 }
View Code

  7.在Home控制器創建一個Chat Action方法:

  
1 public ActionResult Chat()
2         {
3             return View();
4         }
ActionResult Chat

  8.在Views中創建Chat視圖,文件代碼如下:

  
 1 @{
 2     ViewBag.Title = "Chat";
 3 }
 4 
 5 <h2>Chat</h2>
 6 
 7 <div class="container">
 8     <input type="text" id="message" />
 9     <input type="button" id="sendmessage" value="Send" />
10     <input type="hidden" id="displayname" />
11     <ul id="discussion"></ul>
12 </div>
13 
14 @section scripts
15 {
16     <!--引用SignalR庫. -->
17     <script src="~/Scripts/jquery.signalR-2.2.2.min.js"></script>
18     <!--引用自動生成的SignalR 集線器(Hub)腳本.在運行的時候在瀏覽器的Source下可看到 -->
19     <script src="~/signalr/hubs"></script>
20     <script>
21         $(function () {
22             // 引用自動生成的集線器代理
23             var chat = $.connection.serverHub;
24             // 定義伺服器端調用的客戶端sendMessage來顯示新消息
25 
26             chat.client.sendMessage = function (name, message) {
27                 // 向頁面添加消息
28                 $('#discussion').append('<li><strong>' + htmlEncode(name)
29                     + '</strong>: ' + htmlEncode(message) + '</li>');
30                 //if (message == "1") {
31                 //    alert('已收到消息' + message);
32                 //}
33             };
34             // 設置焦點到輸入框
35             $('#message').focus();
36             // 開始連接伺服器
37             $.connection.hub.start().done(function () {
38                 $('#sendmessage').click(function () {
39                     // 調用伺服器端集線器的Send方法
40                     chat.server.send($('#message').val());
41                     // 清空輸入框信息並獲取焦點
42                     $('#message').val('').focus();
43                 });
44             });
45         });
46 
47         // 為顯示的消息進行Html編碼
48         function htmlEncode(value) {
49             var encodedValue = $('<div />').text(value).html();
50             return encodedValue;
51         }
52     </script>
53 }
Chat.cshtml

  9.將App_Start下麵的RouteConfig文件做如下修改,以便程式運行時直接打開Chat頁面:

  

  10.運行程式,然後打開兩個視窗,即可得到如下運行結果:

  

 

3.結束語

  正是由於項目的需要,讓我無意中學習了這個SignalR,個人覺得,真的是非常好用。至於底層的具體實現,以及如何在客戶端中使用,推薦閱讀:https://www.cnblogs.com/aaaaq/p/5929104.html,我的項目Demo亦是借鑒於此。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、首先從網站下載pycharm,如下圖,根據自己電腦的操作系統進行選擇,對於windows系統選擇圖中紅色圈中的區域。 2、下載完成之後如下圖: 3、直接雙擊下載好的exe文件進行安裝,安裝截圖如下: 點擊Next進入下一步: 點擊Next進入下一步: 點擊Install進行安裝: 安裝完成後出現 ...
  • 編程語言Python語法簡單,代碼可讀性高,不僅適合初學者學習,而且崗位需求大,薪資一路也是水漲船高,即使是剛畢業的應屆畢業生,薪資也在12500元每月。 因此,很多程式員很樂意去研究這門編程語言,那麼有哪些值得收藏的Python書單呢? Python入門 《“笨辦法”學Python(第3版)》 本 ...
  • 關於死鎖,估計很多程式員都碰到過,並且有時候這種情況出現之後的問題也不是非常好排查,下麵整理的就是自己對死鎖的認識,以及通過一個簡單的例子來來接死鎖的發生,自己是做python開發的,但是對於死鎖的理解一直是一種模糊的概念,也是想過這次的整理更加清晰的認識這個概念。 用來理解的例子是一個簡單的生產者 ...
  • 用過手機QQ就知道,點擊一個圖片會彈出一個小功能,那就是提取圖片中的文字。非常方便實用,那麼很難實現嗎? 利用Python提取圖片中的文字信息,只需要一行代碼就能搞定! 當然,這是吹牛皮的,但是真正的Python代碼也就第4行,說是一行代碼搞定也沒錯。 示例: 效果 儘管運行Python代碼後也有幾 ...
  • `System.IO.Pipelines`是一個新的庫,旨在簡化在.NET中執行高性能IO的過程。它是一個依賴.NET Standard的庫, 適用於所有.NET實現 。 Pipelines誕生於.NET Core團隊,為使Kestrel成為業界最快的Web伺服器之一。最初從作為Kestrel內部的 ...
  • 在上一篇net core的文章中已經講過如何從零開始搭建WebSocket。 今天聊聊ASP.NET的文件結構,如何用自己的目錄結構組織項目里的文件。 如果用Visual Studio(VS)嚮導或dotnet嚮導,會為我們生成一套MVC通用框架。不過,對於一個要求更特殊或更小的項目,它可能並不如我 ...
  • 三、查詢集合 1.找出List<Product>列表中符合特定條件的所有元素 C#1.1 查詢步驟:迴圈,if判斷,列印 product類 1 using System.Collections; 2 using System.ComponentModel; 3 4 namespace Chapter ...
  • 二、排序Product 1.按名稱對產品進行排序,以特定順序顯示一個列表的最簡單方式就是先將列表排序,再遍歷並顯示其中的項。 C#1.1 使用IComparer對ArrayList進行排序 product類 1 using System.Collections; 2 using System.Com ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...