基于Node.js的WebSocket通信實現(xiàn)
node的依賴包
node中實現(xiàn)Websocket的依賴包有很多,websocket、ws均可,本文選取ws來實現(xiàn),首先安裝依賴
npm install ws
聊天室實例
假如A,B,C,D用戶均通過客戶端連接到Websocket服務,其中每個人發(fā)的消息都需要將其通過Websocket轉(zhuǎn)發(fā)給其他人,此場景類似于服務端將A的消息廣播給組內(nèi)其他用戶。
服務端實現(xiàn)
首先來看服務端程序,具體的工作流程分以下幾步:
- 創(chuàng)建一個WebSocketServer的服務,同時監(jiān)聽8080端口的連接請求。
- 每當有新的客戶端連接該WebSocket成功時,便將該連接push到連接池的數(shù)組中。
- 監(jiān)聽message事件,當該事件發(fā)生時,遍歷連接池,以連接為單位將該消息轉(zhuǎn)發(fā)到對應的客戶端
- 監(jiān)聽close事件,當該事件發(fā)生時,將該連接移出連接池
服務端代碼
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) {
// 連接關閉時,將其移出連接池
clients = clients.filter(function(ws1){
return ws1 !== ws
})
});
});
客戶端實現(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)用戶?
通過上述的demo可以看到,WebSocket都是基于連接的,也就是說我們知道data是從那個connection發(fā)過來,但并不知道使用客戶端的是李雷或者韓梅梅,這可如何是好?再想另一種場景,李雷只想給韓梅梅發(fā)消息,不想將消息廣播給其他客戶端,此時我們就需要在Server端能夠標識用戶身份和連接的對應關系。
于是,需要在客戶端連接到WebSocket之后,緊接著再發(fā)一次請求,告訴Server我的user_id是多少,Server將此user_id與connection之間的關系存儲在hashmap中,至此就建立了user_id與connection的對應關系。當需要發(fā)送消息給對應的客戶端,從此hashmap中取出對應用戶的connection信息,調(diào)用其send方法發(fā)出消息即可。
依賴包
npm install hashmap
服務端實現(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']);
});
});
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- 如何用JS WebSocket實現(xiàn)簡單聊天
- js實現(xiàn)mp3錄音通過websocket實時傳送+簡易波形圖效果
- 原生nodejs使用websocket代碼分享
- node.js基于express使用websocket的方法
- JS實現(xiàn)websocket長輪詢實時消息提示的效果
- nodejs+websocket實時聊天系統(tǒng)改進版
- websocket+node.js實現(xiàn)實時聊天系統(tǒng)問題咨詢
- Node.js websocket使用socket.io庫實現(xiàn)實時聊天室
- Javascript WebSocket使用實例介紹(簡明入門教程)
- 詳解JS WebSocket斷開原因和心跳機制
相關文章
node.js實現(xiàn)websocket的即時通訊詳解
這篇文章主要介紹了深入淺出講解websocket的即時通訊,服務器可以主動向客戶端推送信息,客戶端也可以主動向服務器發(fā)送信息,是真正的雙向平等對話,屬于服務器推送技術(shù)的一種,需要的朋友可以參考下2023-05-05
Node.js實現(xiàn)爬取網(wǎng)站圖片的示例代碼
本文將利用Node.js開發(fā)一個小示例—爬取某圖片網(wǎng)站的圖片,文中涉及的知識點有https模塊、cheerio模塊、fs模塊和閉包,感興趣的可以了解一下2022-04-04
解決node-webkit 不支持html5播放mp4視頻的方法
本文給大家分享的是解決node-webkit 不支持html5播放mp4視頻的方法,其原因大概是因為node-webkit沒有購買mp4格式的專利授權(quán),恩,我們來想個辦法來解決這個事情吧。2015-03-03
nodejs+express實現(xiàn)文件上傳下載管理網(wǎng)站
這篇文章主要為大家詳細介紹了nodejs+express實現(xiàn)文件上傳下載管理的網(wǎng)站,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03
node?NPM庫qs?iconv-lite字符串編碼轉(zhuǎn)換及解析URL查詢學習
這篇文章主要為大家介紹了node?NPM庫之qs解析URL查詢字符串及iconv-lite字符串編碼轉(zhuǎn)換學習,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-07-07

