真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

基于Node.js怎么實(shí)現(xiàn)WebSocket通信

這篇“基于Node.js怎么實(shí)現(xiàn)WebSocket通信”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來(lái)看看這篇“基于Node.js怎么實(shí)現(xiàn)WebSocket通信”文章吧。

創(chuàng)新互聯(lián)公司是一家專注于成都做網(wǎng)站、成都網(wǎng)站建設(shè)與策劃設(shè)計(jì),安陽(yáng)網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)公司做網(wǎng)站,專注于網(wǎng)站建設(shè)十余年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:安陽(yáng)等地區(qū)。安陽(yáng)做網(wǎng)站價(jià)格咨詢:18982081108

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ù)端程序,具體的工作流程分以下幾步:

  1. 創(chuàng)建一個(gè)WebSocketServer的服務(wù),同時(shí)監(jiān)聽(tīng)8080端口的連接請(qǐng)求。

  2. 每當(dāng)有新的客戶端連接該WebSocket成功時(shí),便將該連接push到連接池的數(shù)組中。

  3. 監(jiān)聽(tīng)message事件,當(dāng)該事件發(fā)生時(shí),遍歷連接池,以連接為單位將該消息轉(zhuǎn)發(fā)到對(duì)應(yīng)的客戶端

  4. 監(jiān)聽(tīng)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)





如何發(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']);
  });
});

以上就是關(guān)于“基于Node.js怎么實(shí)現(xiàn)WebSocket通信”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


新聞名稱:基于Node.js怎么實(shí)現(xiàn)WebSocket通信
文章位置:http://weahome.cn/article/jhshjh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部