ASP .NET SignalR起步

来源:https://www.cnblogs.com/heshuaiblog/archive/2019/03/27/10607251.html
-Advertisement-
Play Games

在網站開發中,時常需要使用消息推送功能,http協議是無狀態連接,我們需要一個類似桌面程式中socket保持伺服器和客戶端連接的技術。signalr就是這樣一個技術,他能保持網站頁面和伺服器的一個長連接,時刻監聽伺服器端的信息。實現一個簡單的signalr功能步驟如下。 1.新建一個.net項目,使 ...


在網站開發中,時常需要使用消息推送功能,http協議是無狀態連接,我們需要一個類似桌面程式中socket保持伺服器和客戶端連接的技術。signalr就是這樣一個技術,他能保持網站頁面和伺服器的一個長連接,時刻監聽伺服器端的信息。實現一個簡單的signalr功能步驟如下。

1.新建一個.net項目,使用Nuget引用signalr。會在Script文件下生成jquery.signalR-2.2.0.js文件。

 

 

2.添加Startup類,註冊signalr。

 1 using Microsoft.Owin;
 2 using Owin;
 3 
 4 [assembly: OwinStartup(typeof(VipSignalR.Startup))]
 5 
 6 namespace VipSignalR
 7 {
 8     public class Startup
 9     {
10         public void Configuration(IAppBuilder app)
11         {
12             app.MapSignalR();
13         }
14     }
15 }
View Code

 

3.添加集線器類ChatHub.cs

using Microsoft.AspNet.SignalR;

namespace VipSignalR
{
    public class ChatHub : Hub
    {
        public void Send(string name, string message)
        {
            Clients.All.ReceiveMessage(name, message);
        }
    }
}
View Code

 

4.添加前臺消息發送和接受的代碼

(1)新建一個頁面。

(2)添加html。

your name: <input type="text" id="nameTxt"/><br />
message: <input type="text" id="messageTxt" /><br />
<input type="button" id="sendBtn" value="發送" /><br />

消息記錄:<br/>
<div id="msgDiv"></div>
View Code

(3)引用js文件。

<script src="~/Scripts/jquery-1.6.4.js"></script>
<script src="~/Scripts/jquery.signalR-2.2.0.js"></script>
<script src="~/signalr/hubs"></script>
View Code

其中/signalr/hubs是通過chathubs.cs生成的js文件,可在瀏覽器resource查看。我們通過這個js文件使用在chathubs.cs中定義的方法。

(4)使用signalr。

<script>
    $(function () {
        // 引用自動生成的集線器代理
        //名稱和hub類相同,首字母小寫
        var chat = $.connection.chatHub;

        //接受消息,方法名稱和參數和hub類中動態解析方法名相同
        chat.client.receiveMessage = function (name, message) {
            var msg = "<div>" + name + ": " + message + "</div>";
            $("#msgDiv").append(msg);
        }

        // 集成器連接開始
        $.connection.hub.start().done(function () {
            $('#sendBtn').click(function () {
                //發送消息,方法名和參數和hub類對應,首字母小寫
                chat.server.send($("#nameTxt").val(), $('#messageTxt').val());
            });
        });
    });
</script>
View Code

 

5.運行。通過兩個瀏覽器來測試,可達到如下效果。

 


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

-Advertisement-
Play Games
更多相關文章
  • 是這樣的,大概10天前,我忽然就想造個輪子,這個輪子的主要作用是收集客戶端的日誌,通過服務端存儲到指定的持久化介質中。客戶端和服務端都可以通過簡單的配置實現快速接入 ...
  • C#訪問修飾符,無時無刻都在使用,這裡記錄一下,如果寫錯的地方,歡迎指正。 總結:類只能被定義為public或internal,嵌套類除外,因為嵌套類也具有成員的形態,同時嵌套類可以訪問所屬類的所有成員,包括私有成員!類預設的訪問修飾符是internal,也可以被修飾為public。 參考: htt ...
  • 原文地址:http://www.entityframeworktutorial.net/basics/what-is-entity-in-entityframework.aspx EF中的實體就是繼承自DbContext類的上下文類中的,DbSet類型的實體類。EF API 將這樣的每個實體映射成數 ...
  • 問題 執行若幹個任務,只需要對其中任意一個的完成進行響應。這主要用於:對一個操作進行多種獨立的嘗試,只要一個嘗試完成,任務就算完成。例如,同時向多個 Web 服務詢問股票價格,但是只關心第一個響應的。 文中舉的是向多個Web服務詢問股票價格的例子。 我曾在過往的工作中遇到另一個不太相似的例子。一個問 ...
  • private void button1_Click(object sender, EventArgs e) { string txt = this.richTextBox1.Text; txt = txt.Replace("\n", ",").Replace(" ", "!"). Replac..... ...
  • KoobooJson - 更小更快的C# JSON序列化工具(基於表達式樹構建) 在C#領域,有很多成熟的開源JSON框架,其中最著名且使用最多的是 Newtonsoft.Json ,然而因為版本迭代,其代碼要相容從net2.0到現在的最新的net框架,並且要支持.net平臺下的其它語言,所以最新發 ...
  • Supervisor是採用 Python(2.4+) 開發的,它是一個允許用戶管理 基於 Unix 系統進程的 Client/Server 系統,提供了大量功能來實現對進程的管理。安裝: 安裝完成之後,在 /ect/supervisor/conf.d/ 目錄下新建一個配置文件( touch Hell ...
  • 要求 C端:用戶端(http://www.b.com) A端:管理端(http://admin.b.com) 問題:A端上傳圖片到C端指定文件夾內保存,供C端使用。 方案 ① C端從nuget引入Microsoft.AspNetCore.Mvc.Cors ② Startup文件中的Configure ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...