欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2017年03月11日 10:47:17   作者:董浩_  
這篇文章主要介紹了基于Node.js的WebSocket通信實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

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)聽8080端口的連接請(qǐng)求。
  2. 每當(dāng)有新的客戶端連接該WebSocket成功時(shí),便將該連接push到連接池的數(shù)組中。
  3. 監(jiān)聽message事件,當(dāng)該事件發(fā)生時(shí),遍歷連接池,以連接為單位將該消息轉(zhuǎn)發(fā)到對(duì)應(yīng)的客戶端
  4. 監(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í)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • node.js命令行教程圖文詳解

    node.js命令行教程圖文詳解

    本文先介紹原生的node.js實(shí)現(xiàn)命令行交互,了解原生的api,然后通過(guò)commander.js和inquirer.js實(shí)現(xiàn)一個(gè)完整的交互命令行工具。感興趣的朋友跟隨小編一起看看吧
    2019-05-05
  • node.js實(shí)現(xiàn)websocket的即時(shí)通訊詳解

    node.js實(shí)現(xiàn)websocket的即時(shí)通訊詳解

    這篇文章主要介紹了深入淺出講解websocket的即時(shí)通訊,服務(wù)器可以主動(dòng)向客戶端推送信息,客戶端也可以主動(dòng)向服務(wù)器發(fā)送信息,是真正的雙向平等對(duì)話,屬于服務(wù)器推送技術(shù)的一種,需要的朋友可以參考下
    2023-05-05
  • Node.js實(shí)現(xiàn)爬取網(wǎng)站圖片的示例代碼

    Node.js實(shí)現(xiàn)爬取網(wǎng)站圖片的示例代碼

    本文將利用Node.js開發(fā)一個(gè)小示例—爬取某圖片網(wǎng)站的圖片,文中涉及的知識(shí)點(diǎn)有https模塊、cheerio模塊、fs模塊和閉包,感興趣的可以了解一下
    2022-04-04
  • node.js包管理工具Yarn使用簡(jiǎn)介

    node.js包管理工具Yarn使用簡(jiǎn)介

    這篇文章介紹了JS包管理工具Yarn的基本用法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • express結(jié)合nodejs開啟服務(wù)示例模版

    express結(jié)合nodejs開啟服務(wù)示例模版

    這篇文章主要為大家展現(xiàn)了express結(jié)合nodejs開啟服務(wù)的代碼示例模版,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-04-04
  • 解決node-webkit 不支持html5播放mp4視頻的方法

    解決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-03
  • nodejs+express實(shí)現(xiàn)文件上傳下載管理網(wǎng)站

    nodejs+express實(shí)現(xiàn)文件上傳下載管理網(wǎng)站

    這篇文章主要為大家詳細(xì)介紹了nodejs+express實(shí)現(xiàn)文件上傳下載管理的網(wǎng)站,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • node.js適合游戲后臺(tái)開發(fā)嗎?

    node.js適合游戲后臺(tái)開發(fā)嗎?

    這篇文章主要介紹了node.js適合游戲后臺(tái)開發(fā)嗎?node.js是不是能代替C++開發(fā)游戲后臺(tái)呢?看完本文我想你會(huì)有一定的了解了,需要的朋友可以參考下
    2014-09-09
  • node?NPM庫(kù)qs?iconv-lite字符串編碼轉(zhuǎn)換及解析URL查詢學(xué)習(xí)

    node?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
  • 查詢Node.js版本信息的六種方法

    查詢Node.js版本信息的六種方法

    隨著應(yīng)用程序規(guī)模越來(lái)越龐大,Node.js版本的更新也日益頻繁,本文主要介紹了查詢Node.js版本信息的六種方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-03-03

最新評(píng)論