Signalr實現消息推送

来源:http://www.cnblogs.com/sportsky/archive/2016/06/21/5580682.html
-Advertisement-
Play Games

一、前言 大多數系統裡面好像都有獲取消息的功能,但這些消息來源都不是實時的,比如你開兩個瀏覽器,用兩個不同的賬號登錄,用一個賬號給另外一個賬號發送消息,然而並不會實時收到消息,必須要自己手動F5刷新一下頁面才會顯示自己的消息,這樣感覺用戶體驗不太好。之前看了Learning hard關於Signal ...


一、前言

    大多數系統裡面好像都有獲取消息的功能,但這些消息來源都不是實時的,比如你開兩個瀏覽器,用兩個不同的賬號登錄,用一個賬號給另外一個賬號發送消息,然而並不會實時收到消息,必須要自己手動F5刷新一下頁面才會顯示自己的消息,這樣感覺用戶體驗不太好。之前看了Learning hard關於Signalr的文章,剛好自己項目中有用到獲取實時消息的功能,然而我們項目中就是用js代碼setinterval方法進行1秒刷新讀取數據的,這樣嚴重給伺服器端添加負擔,影響系統性能!所以自己稍微研究了一下,下麵是自己的一些理解,如果有不對的地方,請大家加以斧正!

二、實現原理

下麵談一下自己對Signalr的理解,Signalr可以進行遠程分散式實時通信,都是使用遠程代理來實現,其中有兩大內部對象,第一個是Persisten Connection,用於客戶端和伺服器端的持久連接,第二個是Hub(集線器)對象,主要用於信息交互,將伺服器端的數據推送(push)至客戶端,大致原理如下:

1、客戶端建立與伺服器端的連接

2、客戶端調用伺服器端的方法

3、伺服器端通過客戶端發送的請求,響應數據,再將數據推送至客戶端

三、Signalr實現消息推送

      具體操作實現如下:

      1、創建一個應用程式,我這裡創建的是MVC應用程式

      2、引用相關組件,右鍵引用》選擇管理Nuget程式包

      3、搜索Signalr,如圖所示:

                                 

              點擊安裝,在應用程式的Scripts文件夾裡面會自動生成兩個js文件,如圖所示:

                                  

       4、添加集成器類

                               

       5、註冊signalr/hubs,在Startup.cs裡面添加如下代碼

                              

       6、新建控制器MessageController,然後在控制器裡面新建兩個視圖方法SendMessage和ReceiveMessage,為了讓效果看起來更直觀,一個頁面用於發送消息,一個頁面用於接收消息,如圖所示:

                             

       7、在我們剛剛新建的集成器類MyHub類裡面添加代碼:

           (特別說明一下,這裡的InsertMsg方法主要是將客戶端發送的消息信息保存到資料庫裡面,便於消息讀取,為了快速創建資料庫表,我採用的code first方法來創建的,至於你想用什麼方式創建表,那都是可以的。)

            

namespace Signalr.Models 
{
    [HubName("MyHub")]
    public class MyHub : Hub
    {
        MessageDbContext _db = new MessageDbContext();
        public void Send(string title, string message)
        {
            this.InsertMsg(title, message);
            // 調用所有客戶端的sendMessage方法
            Clients.All.sendMessage(message);
        }

        private void InsertMsg(string title, string message)
        {
            Message msg = new Message();
            msg.Title = title;
            msg.MsgContent = message;
            _db.Messages.Add(msg);
            _db.SaveChanges();
        }
    }
}

表結構如圖所示:

                       

        8、控制器MessageController後臺代碼

public class MessageController : Controller
    {
      private MessageDbContext _db = new MessageDbContext();
        public ActionResult SendMessage()
        {
            return View();
        }

        public ActionResult ReceiveMessage()
        {
            return View();
        }

        [HttpPost]
        public JsonResult MsgCount()  
        {
            var count = this._db.Messages.Where(p=>p.IsRead==0).Count();
          return Json(new {count=count},JsonRequestBehavior.AllowGet);
        }
    }

 

        9、前端頁面代碼(SendMessage.cshtml)

@{
    ViewBag.Title = "發送消息";
}
<title>發送消息</title>
<script src="~/Scripts/jquery-1.10.2.js"></script>
<script src="~/Scripts/jquery.signalR-2.2.0.min.js"></script>
<script src="~/signalr/hubs"></script>
<script type="text/javascript">
    $(function () {
        // 引用自動生成的集線器代理
        var chat = $.connection.MyHub;
        // 定義伺服器端調用的客戶端sendMessage來顯示新消息
        chat.client.sendMessage = function (title, message) {
            // 向頁面發送接收的消息
            sendMsg();
        };
        // 集成器連接開始
        $.connection.hub.start().done(function () {
            sendMsg();
            // 服務連接完成,給發送按鈕註冊單擊事件
            $('#sendmessage').click(function () {
                // 調用伺服器端集線器的Send方法
                chat.server.send($("#title").val(), $('#message').val());
            });
        });
    });

    function sendMsg() {
        var options = {
            url: '/Message/MsgCount',
            type: 'post',
            success: function (data) {
                $("#count").html(data.count);
            }
        };
        $.ajax(options);
    }
</script>


<h2>
    發送消息
</h2>
<div>
    <label>我的消息:</label>
    <span style=" color:red; font-size:30px;" id="count"></span></div>
<p>
    <div>
        標題:
        <input type="text" id="title" />
    </div>
    <br /><br />
    <div>
        內容:
        <textarea id="message" rows="4" cols="30"></textarea>
    </div>
    <br /><br />
    <div>
        <input type="button" id="sendmessage" value="發送" />
    </div>
</p>

         10、前端頁面代碼(ReceiveMessage.cshtml)

@{
    ViewBag.Title = "接受消息";
}
<title>接受消息</title>
<script src="~/Scripts/jquery-1.10.2.js"></script>
<script src="~/Scripts/jquery.signalR-2.2.0.min.js"></script>
<script src="~/signalr/hubs"></script>
<script type="text/javascript">
    $(function () {
        // 引用自動生成的集線器代理
        var chat = $.connection.MyHub;
        // 定義伺服器端調用的客戶端sendMessage來顯示新消息
        chat.client.sendMessage = function (title, message) {
            // 向頁面發送接收的消息
            MsgCount();
            var html = "<div>標題:" + title + "消息內容:" + message + "</div>";
            $("#msgcontent").after(html);
        };
        // 集成器連接開始
        $.connection.hub.start().done(function () {
            MsgCount();
        });
    });
    function MsgCount() {
        var options = {
            url: '/Message/MsgCount',
            type: 'post',
            async:false,
            data: { title: $("#title").val(), msgcontent: $("#sendmessage").val() },
            success: function (data) {
                $("#count").html(data.count);
            }
        };
        $.ajax(options);
    }
</script>


<h2>
    接收消息
</h2>

<div>
    <label>我的消息:</label>
    <span style=" color: red; font-size: 30px;  margin-right:10px;" id="count"></span><br />
    <br />
    <div id="msgcontent"></div>
</div>

 

 好了,大功告成,可能你有點疑問的是這個js文件引用地方在哪裡

不防我們運行頁面,按F12查看一下,它會自動在這裡生成一個js文件,我們只要在頁面中引用這個路徑即可

四、頁面效果(見證奇跡的時刻到了,哈哈哈~~~)

      為了讓頁面效果更為直觀,我這裡用IE打開SendMessage.cshtml頁面,用Google打開ReceiveMessage.cshtml頁面。

 

權責申明

作者:SportSky 出處: http://www.cnblogs.com/sportsky/
本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。如果覺得還有幫助的話,可以點一下右下角的【推薦】,希望能夠持續的為大家帶來好的技術文章!想跟我一起進步麽?那就【關註】我吧


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

-Advertisement-
Play Games
更多相關文章
  • Processor operations mostly involve processing data. This data can be stored in memory and accessed from thereon. However, reading data from and stori ...
  • 1、紅色感嘆號表示這個文件從伺服器上下載下來以後,在本地被修改過。這時執行提交操作就可以了。2、黃色感嘆號表示這個文件在提交的時候發現存在衝突,也就是說有別人在你提交之前對這個文件的同一個版本進行了修改。這時你需要查看這個文件的歷史日誌,和修改了這個文件的人進行溝通,將兩個人的修改內容合併,合併完成 ...
  • //方法一:只禁止多個進程運行 using System; using System.Collections.Generic; using System.Windows.Forms; namespace DuoYeMianIE { static class Program { /// <summar ...
  • 在編程中很可能使用到多級動態目錄,如果使用一般的方法將多級目錄綁定到Treeview就顯得非常局促了,所以,最好的辦法就是使用遞歸,使用遞歸就完全不用去考慮目錄的層次有多深.代碼其實很簡單. View Code 1 protected void Page_Load(object sender, Ev ...
  • 1bit 符號位,11bit 指數位,52bit 尾數位,±5.0E−324 到±1.79E+308 的浮點精度數字 15位有效數字 (char,nchar,text,ntext,varchar,nvarchar,xml) ...
  • 以下是示例的效果圖: WinForm的ListView控制項是可以分組顯示的,還可排序。可以把ListView的View屬性設置為Details完整項目請到下麵網址查找下載http://hovertree.com/hovertreescj/或者:http://hovertree.com/h/bjaf/ ...
  • 前面提到過這個網址:性能註意事項(實體框架) https://msdn.microsoft.com/zh-cn/library/cc853327.aspx註意版本: .NET Framework (current version) (還有一個其他版本, .NET Framework 4). 此文提到 ...
  • 1.ASP.NET Identity 適用所有類型的asp.net程式 ASP.NET MVC, Web Forms, Web Pages, Web API, and SignalR。 2.非常方便的擴展用戶數據欄位。只需一行代碼 設置好你的資料庫連接信息: 修改context的名稱: 打開試圖-》... ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...