在asp.net core 中能夠用WebSocket 或asp.net core SignalR來開發即時通迅。在項目中因爲開發先後端分離,對於SignalR前端技術人員不想依賴juqery和SignalR.js包,後端肯定使用WebSocket 來實現。對於asp.net core有自帶的app.UseWebSockets()中間件,可是使用IIs作爲web代理服務器時,須要在windows系統添加程序iis配置websocket才能使用websocket通信。因而項目引用了一個開源包Fleck。前端
Fleck是對C#Websocket的實現,程序內部使用了System.Net.Sockets類來實現Websocket,不依賴於任何目標框架。 Fleck使用介紹 :https://github.com/statianzo/Fleckgit
下面是msdn文檔原話:github
對於大多數應用程序,咱們建議使用 SignalR,而不是原始 Websocket。 SignalR 可爲 Websocket 不可用的環境提供傳輸回退。 它還可提供簡單的遠程過程調用應用模型。 而且在大多數狀況下,與使用原始 Websocket 相比,SignalR 沒有顯著的性能缺點。web
WebSocket客戶端支持:redis
瀏覽器windows |
支持狀況後端 |
Chrome瀏覽器 |
Chrome version 4+支持服務器 |
Firefoxwebsocket |
Firefox version 5+支持 |
IE |
IE version 10+支持 |
Safari |
IOS 5+支持 |
Android Brower |
Android 4.5+支持 |
在我業務項目中實現的流程是:第三方接口發送數據過來,使用redis進行發佈消息, 在web端進行消息訂閱, 把訂閱的消息經過websocket發送到前端站點,前端界面進行局部數據刷新展現,已解決前端即時消息的展現。
3.1相關包
(1) 發佈訂閱redis包:Install-Package StackExchange.Redis -Version 2.0.601
(2) websocket引用 Fleck 包。Install-Package Fleck -Version 1.1.0
3.2 fleck案例
關於fleck的websocket的參考以下:https://github.com/statianzo/Fleck/tree/master/src/Samples/ConsoleApp
3.3 項目中演示效果
(1) 使用web來作websocket宿主,websocket地址爲:ws://127.0.0.1:8181,以下所示websocket服務已啓動
(2) 啓動前端界面,下圖能夠看到websocket已鏈接
前端頁面鏈接websocket服務關鍵代碼: window.ws = new wsImpl('ws://127.0.0.1:8181',"FootballGoalScore"); 具體參考fleck的websocket示例。
(3) 控制檯程序使用redis模擬發佈信息, web端redis訂閱消息,再經過websocket服務推送消息到前端頁面,經過下圖能夠看到消息已即時傳到
public void FootballScore(IWebSocketConnection websocke) { //redis先訂閱消息 _subscriber.Subscribe("queue2", (msg) => { //websocket服務推送消息 websocke.Send(msg); _lLogger.Debug("消息已發送!"); });
下面是模擬第三方接口消息達到後,使用redis來發布消息,發佈後web端redis自動訂閱。
static void Main(string[] args) { ISubscriber subscriber = new GFRedisSubscriber(); //足球比分 subscriber.Publish("queue2", "1:0"); //即時歐指 subscriber.Publish("queue1", "1.69|3.30|3.78"); Console.ReadLine(); }
參考文獻: