SignalR Self Host+MVC等多端消息推送服務(wù)(二)
一、概述
上次的文章中我們簡單的實現(xiàn)了SignalR自托管的服務(wù)端,今天我們來實現(xiàn)控制臺程序調(diào)用SignalR服務(wù)端來實現(xiàn)推送信息,由于之前我們是打算做審批消息推送,所以我們的demo方向是做指定人發(fā)送信息,至于做聊天消息和全局廣播,這里就不在進行演示了。
二、創(chuàng)建控制臺客戶端
1、在SignalRProject解決方案下新建一個名為Clinet的控制臺
2、在程序包管理控制臺中輸入以下命令
Install-Package Microsoft.AspNet.SignalR.Client
3、修改Clinet項目中的Program.cs代碼
using Microsoft.AspNet.SignalR.Client; using System; namespace Clinet { class Program { static void Main(string[] args) { Console.Write("請輸入用戶名: "); string clientName = Console.ReadLine(); var url = "http://localhost:10086/"; var connection = new HubConnection(url); var chatHub = connection.CreateHubProxy("IMHub"); connection.Start().ContinueWith(t => { if (!t.IsFaulted) { //連接成功,調(diào)用Register方法 chatHub.Invoke("Register", clientName); } }); //客戶端接收實現(xiàn),可以用js,也可以用后端接收 var broadcastHandler = chatHub.On<string, string>("receivePrivateMessage", (name, message) => { Console.WriteLine("[{0}]{1}: {2}", DateTime.Now.ToString("HH:mm:ss"), name, message); }); Console.WriteLine("請輸入接收者名:"); var _name = Console.ReadLine(); Console.WriteLine("請輸入發(fā)送信息!"); while (true) { var _message = Console.ReadLine(); chatHub.Invoke("SendPrivateMessage", _name, _message).ContinueWith(t => { if (t.IsFaulted) { Console.WriteLine("連接失敗!"); } }); Console.WriteLine("請輸入接收者名:"); _name = Console.ReadLine(); Console.WriteLine("請輸入發(fā)送信息!"); } } } }
4、右鍵單擊解決方案——>選擇屬性——>啟動項目——>多啟動項目——>將Clinet和Server設(shè)置為啟動,如下:
5、F5運行后,再開一個Clinet,在第一個Client中輸入用戶名為a,登錄后Server中顯示出登錄a的ID,在另一個Clinet中輸入用戶名為b,登錄后Server中顯示出登錄b的ID,然后根據(jù)提示信息,a Clinet中輸入接收信息的人為b,輸入hello后按Enter后,b Client顯示出了a輸入的信息,如下圖:
自此控制臺調(diào)用SignalR服務(wù)端,實現(xiàn)消息推送的Demo就完成了,今天先寫到這,下一章我們實現(xiàn)B/S端調(diào)用SignalR服務(wù)來推送消息
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
ASP.NET小結(jié)之MVC, MVP, MVVM比較以及區(qū)別(二)
上一篇得到大家的關(guān)注,非常感謝。由于自己對于這些模式的理解也是有限,對于MVC,MVP,MVVM這些模式的比較,是結(jié)合自己的理解,一些地方不一定準確,需要的朋友可以參考下2014-05-05刪除DataTable重復(fù)列,只刪除其中的一列重復(fù)行的解決方法
刪除DataTable重復(fù)列,只刪除其中的一列重復(fù)行,下面的方法就可以,也許有更好的方法,希望大家多多指教2013-02-02Ajax實現(xiàn)異步刷新驗證用戶名是否已存在的具體方法
由于要做一個注冊頁面,看到許多網(wǎng)站上都是使用Ajax異步刷新驗證用戶名是否可用的,所以自己也動手做一個小實例2014-02-02此頁的狀態(tài)信息無效,可能已損壞 的處理辦法及原因分析
此頁的狀態(tài)信息無效,可能已損壞 的處理辦法及原因分析,需要的朋友可以參考一下2013-06-06