【SignalR學習系列】2. 第一個SignalR程式

来源:http://www.cnblogs.com/Soulless/archive/2017/07/21/7217293.html
-Advertisement-
Play Games

新建項目 1.使用VisualStudio 2015 新建一個Web項目 2.選擇空模板 3.添加一個新的SignalR Hub Class (v2)類文件,並修改類名為ChatHub 4.修改ChatHub代碼 5.在項目里添加OWIN Startup Class,並改名為Startup 6.修改 ...


新建項目

1.使用VisualStudio 2015 新建一個Web項目

2.選擇空模板

3.添加一個新的SignalR Hub Class (v2)類文件,並修改類名為ChatHub

 

4.修改ChatHub代碼

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using Microsoft.AspNet.SignalR;

namespace SignalRDemo
{
    public class ChatHub : Hub
    {
        public void Send(string name, string message)
        {
            // Call the broadcastMessage method to update clients.
            Clients.All.broadcastMessage(name, message);
        }
    }
}

5.在項目里添加OWIN Startup Class,並改名為Startup

6.修改類Startup代碼

using System;
using System.Threading.Tasks;
using Microsoft.Owin;
using Owin;

[assembly: OwinStartup(typeof(SignalRDemo.Startup))]

namespace SignalRDemo
{
    public class Startup
    {
        public void Configuration(IAppBuilder app)
        {
            // Any connection or hub wire up and configuration should go here
            app.MapSignalR();
        }
    }
}

7.添加index.html頁面,並設置為啟動頁面

8.在Nuget里升級jQuery和SignalR到最新版,預設創建的模板里的jQuery和SignalR可能是老版本的

8.編輯index.html頁面內容,需要註意jQuery版本和SignalR版本

<!DOCTYPE html>
<html>
<head>
    <title>SignalR Simple Chat</title>
    <style type="text/css">
        .container {
            background-color: #99CCFF;
            border: thick solid #808080;
            padding: 20px;
            margin: 20px;
        }
    </style>
</head>
<body>
    <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>
    <!--Script references. -->
    <!--Reference the jQuery library. -->
    <script src="Scripts/jquery-3.1.1.min.js"></script>
    <!--Reference the SignalR library. -->
    <script src="Scripts/jquery.signalR-2.2.2.min.js"></script>
    <!--Reference the autogenerated SignalR hub script. -->
    <script src="signalr/hubs"></script>
    <!--Add script to update the page and send messages.-->
    <script type="text/javascript">
        $(function () {
            // Declare a proxy to reference the hub.
            var chat = $.connection.chatHub;
            // Create a function that the hub can call to broadcast messages.
            chat.client.broadcastMessage = function (name, message) {
                // Html encode display name and message.
                var encodedName = $('<div />').text(name).html();
                var encodedMsg = $('<div />').text(message).html();
                // Add the message to the page.
                $('#discussion').append('<li><strong>' + encodedName
                    + '</strong>:&nbsp;&nbsp;' + encodedMsg + '</li>');
            };
            // Get the user name and store it to prepend to messages.
            $('#displayname').val(prompt('Enter your name:', ''));
            // Set initial focus to message input box.
            $('#message').focus();
            // Start the connection.
            $.connection.hub.start().done(function () {
                $('#sendmessage').click(function () {
                    // Call the Send method on the hub.
                    chat.server.send($('#displayname').val(), $('#message').val());
                    // Clear text box and reset focus for next comment.
                    $('#message').val('').focus();
                });
            });
        });
    </script>
</body>
</html>

 9.啟動調試,輸入名字,然後就可以對話了。這時候再打開另一個瀏覽器,輸入名字,兩個客戶端之間就可以對話了,一個簡單的聊天室就這樣做好了。

 

代碼解釋

SignalR Hubs

ChatHub繼承於類Microsoft.AspNet.SignalR.Hub。

客戶端通過調用ChatHub.Send來發送信息,hub通過調用Clients.All.broadcastMessage來給客戶端發送信息。

Send方法體現了幾個Hub概念:

  • 在Hub里聲明公開的方法(比如實例里的 Send 方法),讓客戶端可以調用它們。
  • 使用 Microsoft.AspNet.SignalR.Hub.Clients 的 dynamic 屬性訪問各個客戶端並連接到當前的hub。
  • 調用客戶端上的一個方法(比如實例里的 broadcastMessage 方法)去更新客戶端。

 

SignalR and jQuery

首先聲明一個hub代理。

var chat = $.connection.chatHub;

然後在js腳本里創建一個回調函數,服務端的Hub類會調用這個方法來更新各個客戶端。

chat.client.broadcastMessage = function (name, message) {
        // Html encode display name and message. 
        var encodedName = $('<div />').text(name).html();
        var encodedMsg = $('<div />').text(message).html();
        // Add the message to the page. 
        $('#discussion').append('<li><strong>' + encodedName
            + '</strong>:&nbsp;&nbsp;' + encodedMsg + '</li>');
    };

最後開始一個連接,創建一個函數來處理頁面上的Send按鈕事件。

$.connection.hub.start().done(function () {
                $('#sendmessage').click(function () {
                    // 調用Hub上的send方法
                    chat.server.send($('#displayname').val(), $('#message').val());
                    // 清理textbox並聚焦到textbox上
                    $('#message').val('').focus();
                });
            });

 

源代碼鏈接:

https://pan.baidu.com/s/1eSP91GA 密碼: r67v

 

參考鏈接:

https://docs.microsoft.com/zh-cn/aspnet/signalr/overview/getting-started/tutorial-getting-started-with-signalr


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

-Advertisement-
Play Games
更多相關文章
  • 一、前言 對於不久開源的surging受到不少.net同學的青睞,也受到.net core學習小組的關註,邀請加入.NET China Foundation 以方便國內.net core開源項目的推廣,我果斷接受邀請加入了隊伍進行互相交流學習,最近也更新了surging新的版本 更新內容: 1. C ...
  • EF(Entity Framework的簡稱,下同)有三種方式,分別是:DataBase First、 Model First和Code First。 下麵是Db First的方式: 1. 資料庫庫中存在兩個表,一個是專業表,一個學生表,一個學生只能屬於一個專業: 其中T_Major是專業表,T_S ...
  • 騰訊推出微信小程式也有一段時間了,在各種行業裡面也都掀起一陣陣的熱潮,很多APP應用被簡化為小程式的功能迅速推出,同時也根據小程式的特性推出各種獨具匠心的應用,相對傳統的APP來說,微信小程式確實能夠大大降低開發成本和難度,但也意味著需要掌握整個微信小程式的各種介面功能、應用場景等相關技術點,本篇隨... ...
  • 創建項目 創建一個空的 Web 項目,併在 Nuget 裡面添加 SignalR,jQuery UI 包,添加以後項目里包含了 jQuery,jQuery.UI ,和 SignalR 的腳本。 創建基礎應用 添加一個 SignalR Hub 類,並命名為 MoveShapeHub ,更新代碼。 當程 ...
  • 如果有相同的類,一般可以使用 partial 讓他寫在多個文件,那麼如何把多個文件合併?請看 MainWindow.xaml 和 MainWindow.xaml.cs 其中 代碼文件被摺疊,那麼如何做代碼的摺疊 ...
  • 第一個ServiceStack服務框架 最近剛接觸ServiceStack,就嘗試著寫了第一個服務框架,難免出錯,還望同道們多多指正。 關於ServiceStack相關的概念不在做詳細的敘述,網上研究此領域的大神們比比皆是。 ServiceStack的官網地址為: https://github.co ...
  • 採用Razor引擎的View文件最終都會編譯成一個WebViewPage類型, 通過自定義WebViewPage,添加相應的屬性和方法,你可以很方便的在View里調用, 自定義WebViewPage只需要簡單的兩步: 1:定義一個類,並讓他繼承自WebViewPage 2:配置View目錄下的Web ...
  • 現在幾乎所有的APP都集成了向微博,微信等社交平臺分享的功能。這些社交平臺官方也提供了SDK讓開發者使用,對於Android和IOS平臺而言,只需要下載官方的SDK,按照官方說明文檔進行集成就可以輕鬆實現了。 但是對於Xamarin來說,並沒有官方的SDK,這個時候就需要我們手動進行綁定了,首先從A ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...