ASP.NET Core 2.2 WebApi 系列【九】使用SignalR

来源:https://www.cnblogs.com/tenghao510/archive/2019/11/28/11937953.html
-Advertisement-
Play Games

1.添加 SignalR 客戶端庫 右鍵點擊項目->然後選擇“添加” >“客戶端庫” 提供程式選擇:unpkg ,庫選擇:@aspnet/[email protected] 選擇“選擇特定文件” ,展開“dist/browser” 文件夾,然後選擇“signalr.js” 和“signalr.min.js” ...


1.添加 SignalR 客戶端庫

右鍵點擊項目->然後選擇“添加” >“客戶端庫” 

提供程式選擇:unpkg ,庫選擇:@aspnet/[email protected]

選擇“選擇特定文件” ,展開“dist/browser” 文件夾,然後選擇“signalr.js” 和“signalr.min.js” 

選擇指定位置安裝即可

2.定義Hub集線器

創建MessageHub 並繼承Hub。Hub類管理連接、組和消息

using System.Collections.Generic;
using System.Threading.Tasks;
using Microsoft.AspNetCore.SignalR;

namespace NetCoreWebApi.SignalR
{
    /// <summary>
    /// Message集線器
    /// </summary>
    public class MessageHub : Hub
    {
        /// <summary>
        /// 存放已連接信息
        /// </summary>
        public static readonly Dictionary<string, string> Connections = new Dictionary<string, string>();
        /// <summary>
        /// 發送消息
        /// </summary>
        /// <param name="loginNo"></param>
        /// <param name="message"></param>
        /// <returns></returns>
        public async Task SendMessage(string loginNo, string message)
        {
            Connections.TryGetValue(loginNo, out string clientId);
            //ReceiveMessage 客戶端接受方法
            await Clients.Client(clientId).SendAsync("ReceiveMessage", message);
        }
        /// <summary>
        /// 客戶端登錄成功保存用戶賬號和客戶端Id
        /// </summary>
        /// <param name="loginNo"></param>
        public void SendLogin(string loginNo)
        {
            //判斷用戶有沒有登陸過(沒登陸過插入用戶名和Id,登陸過修改用戶名和Id)
            if (!Connections.ContainsKey(loginNo))
            {
                Connections.Add(loginNo, Context.ConnectionId);
            }
            else
            {
                Connections[loginNo] = Context.ConnectionId;
            }
        }
    }
}

3.配置SignalR

我們需要在Startup.cs啟動類的ConfigureServices註冊SignalR服務

            services.AddSignalR();

設置SignalR路由

            //設置SignalR路由,指向自定義類MessageHub
            app.UseSignalR(route =>
            {
                route.MapHub<MessageHub>("/MessageHub");
            });

註意:UseSignalR 必須在 UseMvc 之前調用!

4.編寫SignalR 客戶端代碼

引用signalr.js類庫文件到html中

<!DOCTYPE HTML>
<html>
<head>
</head>
<body>
    <div style="text-align: center;margin-top: 5%">
        <input type="text" id="message" placeholder="消息" />
        <button type="button" id="sendBtn">發送</button>
    </div>
    <script src="../Resources/lib/signalr/dist/browser/signalr.js"></script>
</body>
</html>
<script>
    var connection = new signalR.HubConnectionBuilder()
        //配置路由
        .withUrl("/MessageHub")
        //日誌信息
        .configureLogging(signalR.LogLevel.Information)
        //創建
        .build();
    //接受消息
    connection.on("ReceiveMessage", (message) => {
        alert("收到消息===>" + message);
    });
    //發送消息
    document.getElementById("sendBtn").addEventListener("click", function () {
        var message = document.getElementById('message').value;
        connection.invoke("SendMessage", "[email protected]", message).catch(err =>
            console.error(err.toString())
        );
    });
    //開始連接
    connection.start().then(e => {
        connection.invoke("SendLogin", "[email protected]").catch(err =>
            console.error(err.toString())
        );
    }).catch(err => console.error(err.toString()));
</script>

5.運行程式

打開html頁面,F12在 Console 看到列印以下信息說明連接成功。

 

 輸入文字,點擊發送按鈕。(我這裡是alert,如有其它需求,可在接收消息回調裡面處理邏輯)

 

6.從控制器發佈消息

將消息從外部發送到 hub。當使用控制器時,需要註入一個 IHubContext 實例。

using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.SignalR;
using NetCoreWebApi.SignalR;

namespace NetCoreWebApi.Controllers
{
    /// <summary>
    /// SignalR推送
    /// </summary>
    [Route("api/hub")]
    [ApiController]
    public class HubController : Controller
    {
        private readonly IHubContext<MessageHub> _hubContext;
        /// <summary>
        /// 構造函數
        /// </summary>
        /// <param name="hubClients"></param>
        public HubController(IHubContext<MessageHub> hubClients)
        {
            _hubContext = hubClients;
        }
        /// <summary>
        /// 測試SignalR推送
        /// </summary>
        /// <param name="loginNo"></param>
        [HttpGet]
        [Route("pushMsg")]
        public void PushMsg(string loginNo)
        {
            if (string.IsNullOrWhiteSpace(loginNo))
            {
                //給所有人推送消息
                _hubContext.Clients.All.SendAsync("ReceiveMessage", "這是控制器發送的消息");
            }
            else
            {
                //給指定人推送
                MessageHub.Connections.TryGetValue(loginNo, out string id);
                _hubContext.Clients.Client(id).SendAsync("ReceiveMessage", "這是控制器發送的消息");
            }
        }
    }
}

調用介面測試


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

-Advertisement-
Play Games
更多相關文章
  • 對於非純字元串組成的列表,需要使用map(str, 列表)轉換,純字元串組成的列表則不需要轉換 ...
  • 1.python之logger日誌通用配置文件 2.放入項目即可直接使用 ...
  • Intellj IDEA快捷鍵入門 之 Ctrl+Space(空格) 時間 :2019/11/28 系統 :Win10系統 背景 : 步驟 : 1.win 設置 時間和語言 語言 添加語言 2.這裡選最基本的就好,不想選亂七八糟的,點擊"安裝" 3.安裝完成後(重啟完成後),這裡就會有兩種語言,把E ...
  • 正則匹配並且可以捕獲到()這個裡面的子表達式的值,linux的grep命令沒辦法捕獲子表達式的值,只能獲取到整條正則匹配的內容 上面的正則中驗證了.*是貪婪 .*?是非貪婪 ,下麵匹配的字元串切片第一條是整條數據,後面的每一個對應正則括弧里捕獲的內容 tao@tao-PC:/var/www/html ...
  • 上一篇說瞭如何使用 Topshelf 組件快速創建Windows服務,接下來介紹如何使用 Quartz.net 關於Quartz.net的好處,網上搜索都是一大把一大把的,我就不再多介紹。 先介紹需要用到的插件: Quartz版本我用的 2.6.2的, 沒有用3.0以上的,因為你用了就會知道,會列印 ...
  • static void GetNetVersionDemo() { using (RegistryKey ndpKey = RegistryKey.OpenBaseKey(RegistryHive.LocalMachine, RegistryView.Registry32).OpenSubKey(@... ...
  • 畢業一年半了,從net framework過渡到net core,感覺擴開了自己的眼界,聽說了docker、微服務、CI/CD等等技術。也跟著學了一些,感覺對技術的世界還是充滿了興趣。也有過一絲迷茫,看到那麼多新穎的技術卻無從下手。所以有想法開始嘗試寫博客,記錄自己的點滴和學習記錄吧。 在這工作的一 ...
  • 之前實現的那版依賴註入框架基本可用,但是感覺還是不夠靈活,而且註冊服務和解析服務在同一個地方感覺有點彆扭,有點職責分離不夠。於是借鑒 Autofac 的做法,增加了一個 `ServiceContainerBuilder` 來負責註冊服務,`ServiceContainer`負責解析服務,並且增加了一... ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...