這篇文章將為大家詳細講解有關(guān)基于Node.js如何實現(xiàn)WebSocket通信,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

node的依賴包
node中實現(xiàn)Websocket的依賴包有很多,websocket、ws均可,本文選取ws來實現(xiàn),首先安裝依賴
npm install ws
聊天室實例
假如A,B,C,D用戶均通過客戶端連接到Websocket服務(wù),其中每個人發(fā)的消息都需要將其通過Websocket轉(zhuǎn)發(fā)給其他人,此場景類似于服務(wù)端將A的消息廣播給組內(nèi)其他用戶。
服務(wù)端實現(xiàn)
首先來看服務(wù)端程序,具體的工作流程分以下幾步:
創(chuàng)建一個WebSocketServer的服務(wù),同時監(jiān)聽8080端口的連接請求。
每當(dāng)有新的客戶端連接該WebSocket成功時,便將該連接push到連接池的數(shù)組中。
監(jiān)聽message事件,當(dāng)該事件發(fā)生時,遍歷連接池,以連接為單位將該消息轉(zhuǎn)發(fā)到對應(yīng)的客戶端
監(jiān)聽close事件,當(dāng)該事件發(fā)生時,將該連接移出連接池
服務(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)閉時,將其移出連接池
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端能夠標(biāo)識用戶身份和連接的對應(yīng)關(guān)系。
于是,需要在客戶端連接到WebSocket之后,緊接著再發(fā)一次請求,告訴Server我的user_id是多少,Server將此user_id與connection之間的關(guān)系存儲在hashmap中,至此就建立了user_id與connection的對應(yīng)關(guān)系。當(dāng)需要發(fā)送消息給對應(yīng)的客戶端,從此hashmap中取出對應(yīng)用戶的connection信息,調(diào)用其send方法發(fā)出消息即可。
依賴包
npm install hashmap
服務(wù)端實現(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']);
});
});關(guān)于“基于Node.js如何實現(xiàn)WebSocket通信”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.yijiale78.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
文章標(biāo)題:基于Node.js如何實現(xiàn)WebSocket通信-創(chuàng)新互聯(lián)
本文URL:http://www.yijiale78.com/article2/ceihic.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、用戶體驗、網(wǎng)站導(dǎo)航、域名注冊、網(wǎng)頁設(shè)計公司、面包屑導(dǎo)航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容