基于Node.js的WebSocket通信實(shí)現(xiàn)
node的依賴包
node中實(shí)現(xiàn)Websocket的依賴包有很多,websocket、ws均可,本文選取ws來(lái)實(shí)現(xiàn),首先安裝依賴
npm install ws
聊天室實(shí)例
假如A,B,C,D用戶均通過(guò)客戶端連接到Websocket服務(wù),其中每個(gè)人發(fā)的消息都需要將其通過(guò)Websocket轉(zhuǎn)發(fā)給其他人,此場(chǎng)景類似于服務(wù)端將A的消息廣播給組內(nèi)其他用戶。
服務(wù)端實(shí)現(xiàn)
首先來(lái)看服務(wù)端程序,具體的工作流程分以下幾步:
- 創(chuàng)建一個(gè)WebSocketServer的服務(wù),同時(shí)監(jiān)聽8080端口的連接請(qǐng)求。
- 每當(dāng)有新的客戶端連接該WebSocket成功時(shí),便將該連接push到連接池的數(shù)組中。
- 監(jiān)聽message事件,當(dāng)該事件發(fā)生時(shí),遍歷連接池,以連接為單位將該消息轉(zhuǎn)發(fā)到對(duì)應(yīng)的客戶端
- 監(jiān)聽close事件,當(dāng)該事件發(fā)生時(shí),將該連接移出連接池
服務(wù)端代碼
var WebSocketServer = require('ws').Server, wss = new WebSocketServer({port: 8080}); // 連接池 var clients = []; wss.on('connection', function(ws) { // 將該連接加入連接池 clients.push(ws); ws.on('message', function(message) { // 廣播消息 clients.forEach(function(ws1){ if(ws1 !== ws) { ws1.send(message); } }) }); ws.on('close', function(message) { // 連接關(guān)閉時(shí),將其移出連接池 clients = clients.filter(function(ws1){ return ws1 !== ws }) }); });
客戶端實(shí)現(xiàn)
<html> <input type="text" id="text"> <input type="button" onclick="sendMessage()" value="online"> <script> var ws = new WebSocket("ws://localhost:8080"); ws.onopen = function (e) { console.log('Connection to server opened'); } ws.onmessage = function(event) { console.log('Client received a message', event); }; ws.onclose = function (e) { console.log('connection closed.'); } function sendMessage() { ws.send(document.getElementById('text').value); } </script> </html>
如何發(fā)現(xiàn)用戶?
通過(guò)上述的demo可以看到,WebSocket都是基于連接的,也就是說(shuō)我們知道data是從那個(gè)connection發(fā)過(guò)來(lái),但并不知道使用客戶端的是李雷或者韓梅梅,這可如何是好?再想另一種場(chǎng)景,李雷只想給韓梅梅發(fā)消息,不想將消息廣播給其他客戶端,此時(shí)我們就需要在Server端能夠標(biāo)識(shí)用戶身份和連接的對(duì)應(yīng)關(guān)系。
于是,需要在客戶端連接到WebSocket之后,緊接著再發(fā)一次請(qǐng)求,告訴Server我的user_id是多少,Server將此user_id與connection之間的關(guān)系存儲(chǔ)在hashmap中,至此就建立了user_id與connection的對(duì)應(yīng)關(guān)系。當(dāng)需要發(fā)送消息給對(duì)應(yīng)的客戶端,從此hashmap中取出對(duì)應(yīng)用戶的connection信息,調(diào)用其send方法發(fā)出消息即可。
依賴包
npm install hashmap
服務(wù)端實(shí)現(xiàn)
var WebSocketServer = require('ws').Server, webSocketServer = new WebSocketServer({port: 8080}); var HashMap = require('hashmap'); // record the client var userConnectionMap = new HashMap(); var connectNum = 0; // connection webSocketServer.on('connection', function(ws) { ++ connectNum; console.log('A client has connected. current connect num is : ' + connectNum); ws.on('message', function(message) { var objMessage = JSON.parse(message); var strType = objMessage['type']; switch(strType) { case 'online' : userConnectionMap.set(objMessage['from'], ws); break; default: var targetConnection = userConnectionMap.get(objMessage['to']); if (targetConnection) { targetConnection.send(message); } } }); ws.on('close', function(message) { var objMessage = JSON.parse(message); userConnectionMap.remove(objMessage['from']); }); });
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 如何用JS WebSocket實(shí)現(xiàn)簡(jiǎn)單聊天
- js實(shí)現(xiàn)mp3錄音通過(guò)websocket實(shí)時(shí)傳送+簡(jiǎn)易波形圖效果
- 原生nodejs使用websocket代碼分享
- node.js基于express使用websocket的方法
- JS實(shí)現(xiàn)websocket長(zhǎng)輪詢實(shí)時(shí)消息提示的效果
- nodejs+websocket實(shí)時(shí)聊天系統(tǒng)改進(jìn)版
- websocket+node.js實(shí)現(xiàn)實(shí)時(shí)聊天系統(tǒng)問(wèn)題咨詢
- Node.js websocket使用socket.io庫(kù)實(shí)現(xiàn)實(shí)時(shí)聊天室
- Javascript WebSocket使用實(shí)例介紹(簡(jiǎn)明入門教程)
- 詳解JS WebSocket斷開原因和心跳機(jī)制
相關(guān)文章
node.js實(shí)現(xiàn)websocket的即時(shí)通訊詳解
這篇文章主要介紹了深入淺出講解websocket的即時(shí)通訊,服務(wù)器可以主動(dòng)向客戶端推送信息,客戶端也可以主動(dòng)向服務(wù)器發(fā)送信息,是真正的雙向平等對(duì)話,屬于服務(wù)器推送技術(shù)的一種,需要的朋友可以參考下2023-05-05Node.js實(shí)現(xiàn)爬取網(wǎng)站圖片的示例代碼
本文將利用Node.js開發(fā)一個(gè)小示例—爬取某圖片網(wǎng)站的圖片,文中涉及的知識(shí)點(diǎn)有https模塊、cheerio模塊、fs模塊和閉包,感興趣的可以了解一下2022-04-04express結(jié)合nodejs開啟服務(wù)示例模版
這篇文章主要為大家展現(xiàn)了express結(jié)合nodejs開啟服務(wù)的代碼示例模版,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-04-04解決node-webkit 不支持html5播放mp4視頻的方法
本文給大家分享的是解決node-webkit 不支持html5播放mp4視頻的方法,其原因大概是因?yàn)閚ode-webkit沒(méi)有購(gòu)買mp4格式的專利授權(quán),恩,我們來(lái)想個(gè)辦法來(lái)解決這個(gè)事情吧。2015-03-03nodejs+express實(shí)現(xiàn)文件上傳下載管理網(wǎng)站
這篇文章主要為大家詳細(xì)介紹了nodejs+express實(shí)現(xiàn)文件上傳下載管理的網(wǎng)站,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03node?NPM庫(kù)qs?iconv-lite字符串編碼轉(zhuǎn)換及解析URL查詢學(xué)習(xí)
這篇文章主要為大家介紹了node?NPM庫(kù)之qs解析URL查詢字符串及iconv-lite字符串編碼轉(zhuǎn)換學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07