亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Nodejs環(huán)境實現(xiàn)socket通信過程解析

 更新時間:2020年07月03日 10:24:54   作者:奔跑的太陽花  
這篇文章主要介紹了Nodejs環(huán)境實現(xiàn)socket通信過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

結(jié)構(gòu):

socket是應用層和傳輸層的橋梁。(傳輸層之上的協(xié)議所涉及的數(shù)據(jù)都是在本機處理的,并沒進入網(wǎng)絡中)

涉及數(shù)據(jù):

socket所涉及的數(shù)據(jù)是報文,是明文。

作用:

建立長久鏈接,供網(wǎng)絡上的兩個進程通信。

nodejs環(huán)境下的簡單通信。

代碼:

serve:

// 1 引入模塊
const net = require('net');
// 2 創(chuàng)建服務器
let clientArr = [];
const server = net.createServer();
// 3 綁定鏈接事件
server.on('connection',(person)=>{
console.log(clientArr.length);
// 記錄鏈接的進程
person.id = clientArr.length;
clientArr.push(person);
person.setEncoding('utf8');
// 客戶socket進程綁定事件
person.on('data',(chunk)=>{
console.log(chunk);
clientArr.forEach((val)=>{
// 數(shù)據(jù)寫入全部客戶進程中
val.write(chunk);
})
})
person.on('close',(p1)=>{
clientArr[p1.id] = null;
} )
person.on('error',(p1)=>{
clientArr[p1.id] = null;
})
})
server.listen(800);

client:

// 1 引入模塊
const net = require('net');
const readline = require('readline');
// 2 創(chuàng)建套接字和輸入輸出命令行
let rl = readline.createInterface({
// 調(diào)用std接口
input:process.stdin,
output:process.stdout
})
let client = new net.Socket();
// 3 鏈接
client.connect(800,'localhost');

client.setEncoding('utf8');
client.on('data',(chunk)=>{

})
client.on('error',(e)=>{
console.log(e.message);
})
// 綁定輸io流事件,獲取輸入輸出字符
rl.on('line',(mes)=>{
client.write(mes);
})

小結(jié):

server端:綁定連接事件 --> 在連接事件中管理客戶端進程對象(1,把添加到數(shù)組中 2,處理客戶端發(fā)來的數(shù)據(jù))-->開啟端口監(jiān)聽請求 。

client端:創(chuàng)建連接服務器用的套接字 --> 連接服務器 。

socket建立的連接是長久連接。而應用層的http協(xié)議是3次握手協(xié)議,是短連接。

socket工作原理和http類似,只是不規(guī)定斷開連接的時間??梢园裩ttp理解成一個人辦一件事情就跑一次連接流程。socket理解成只跑一次連接流程,只到把所有的事情都做完了才回去。

Socket主要作用是實現(xiàn)客戶端與服務端的實時通信保持通話,它不像ajax請求,每次對話完成后都會把連接斷開。Socket通信在

Node.js中實現(xiàn)其實很簡單,沒有想象中復雜,基本上只要懂得監(jiān)聽(.on)和推送(.emit)消息,即能實現(xiàn)Socket通信。

Socket服務端

在服務端使用Socket,需先引入socket.io模塊,該模塊詳細文檔可參考https://socket.io/

cnpm install socket.io

服務端實例代碼如下:

var server = app.listen(8081, "127.0.0.1", function() {
  var host = server.address().address;
  var port = server.address().port;
});
 
/********************socketIO********************/
var io = require('socket.io').listen(server);
// 建立連接
io.sockets.on('connection', function(socket) { //此處每個回調(diào)socket就是一個獨立的客戶端,通常會用一個公共列表數(shù)組統(tǒng)一管理
  // 連接斷開,如關閉頁面時觸發(fā)
  socket.on('disconnect', function() {
    console.log('已斷開鏈接');
  });
  // 監(jiān)聽客戶端發(fā)送的消息
  socket.on('clientmessage', function(data) {
    //推送給除自己外其他所有用戶的消息,類似于廣播
    socket.broadcast.emit('message', {
      text: '你的朋友上線了'
    });
  });
  //發(fā)送給自己的消息
  socket.emit('message', {
    text: '你上線了'
  });
});

上例中實現(xiàn)了4步:

1. 建立連接并添加斷開連接監(jiān)聽。

2. 建立clientmessage監(jiān)聽,當客戶端發(fā)來該名稱的事件時,服務器向除自己外其他的用戶廣播事件名稱為message的消息。

3.在剛建立連接時,向客戶端推送事件名稱為message的消息。

其中主要應用到的函數(shù)有5個:

  • .on('connection', function(socket){ }):與客戶端建立連接時監(jiān)聽。
  • .on('disconnect', function(){ }):與客戶端斷開連接時監(jiān)聽。
  • .on('event-name', function(data) { }):監(jiān)聽客戶端發(fā)來的消息。
  • .broadcast.emit('event-name', { }):向除自己外的所有其他用戶廣播消息。
  • .emit('event-name', { }):僅向當前連接的客戶端(自己)推送消息。

(注)相關客戶端的接口關聯(lián)請往下看客戶端的例子。

Socket客戶端

需先去下載socket.io.js文件,下載地址為:https://github.com/socketio/socket.io-client

客戶端實例代碼如下:

<!DOCTYPE html>
<html>
 
  <head>
    <meta charset="UTF-8">
    <title>socketio測試</title>
    <script>
      var tmp_html = '<link rel="stylesheet" href="../js/libs/bootstrap/3.3.7/css/bootstrap.css" rel="external nofollow" />';
      tmp_html += '<script src="../js/libs/jquery/3.2.1/jquery.js"><\/script>';
      tmp_html += '<script src="../js/libs/bootstrap/3.3.7/bootstrap.js"><\/script>';
      tmp_html += '<script src="../js/libs/socketio/socket.io.js"><\/script>';
      document.write(tmp_html);
      document.close();
    </script>
  </head>
 
  <body>
    <button id="btn">發(fā)送消息</button>
  </body>
  <script>
    var socket = io.connect('http://127.0.0.1:8081');
    socket.on('message', function(data) {
      console.log(data.text);
    })
 
    $("#btn").click(function() {
      socket.emit('clientmessage', {
        text: "hello"
      });
    });
  </script>
</html>

客戶端主要應用到的函數(shù)有2個:

  • .on('event-name', function(data) { }):監(jiān)聽服務端發(fā)來的消息。
  • .emit('event-name', { }):向服務端推送消息。

Socket即時通信就是那么簡單,而且在連接斷開時還會自動重連。還有一種實現(xiàn)方法就是使用net模塊的套接字,可以直接查看Node.js文檔。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • nvm管理node無法正常切換node版本問題的解決方法

    nvm管理node無法正常切換node版本問題的解決方法

    相信一定會有存在一些小伙伴 明明都已經(jīng)按著操作卸載node 和安裝nvm 了但是 依舊無法正常通過nvm管理node,本文將給大家介紹nvm管理node無法正常切換node版本問題的解決方法,需要的朋友可以參考下
    2024-01-01
  • node使用promise替代回調(diào)函數(shù)

    node使用promise替代回調(diào)函數(shù)

    這篇文章主要介紹了node使用promise替代回調(diào)函數(shù),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • nodejs中使用多線程編程的方法實例

    nodejs中使用多線程編程的方法實例

    這篇文章主要介紹了nodejs中使用多線程編程的方法實例,本文使用nodejs addon借助c/c++的能力擴展nodejs多線程編程,需要的朋友可以參考下
    2015-03-03
  • node爬取微博的數(shù)據(jù)的簡單封裝庫nodeweibo使用指南

    node爬取微博的數(shù)據(jù)的簡單封裝庫nodeweibo使用指南

    這篇文章主要介紹了node爬取微博的數(shù)據(jù)的簡單封裝庫nodeweibo使用指南,需要的朋友可以參考下
    2015-01-01
  • node腳手架搭建服務器實現(xiàn)token驗證的方法

    node腳手架搭建服務器實現(xiàn)token驗證的方法

    這篇文章主要介紹了node腳手架搭建服務器實現(xiàn)token驗證的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • 使用命令行升級Node.js的版本的操作指南

    使用命令行升級Node.js的版本的操作指南

    這篇文章主要給大家介紹了關于如何使用命令行升級Node.js的版本的操作指南,文中介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧
    2023-11-11
  • nodejs教程之制作一個簡單的文章發(fā)布系統(tǒng)

    nodejs教程之制作一個簡單的文章發(fā)布系統(tǒng)

    本文主要講述了使用nodejs制作一個簡單的文章發(fā)布系統(tǒng),使用mongodb數(shù)據(jù)庫,時間比較緊,功能做的也比較簡單,僅僅是增刪改查,外加附近上傳,有相同需求的小伙伴可以參考下
    2014-11-11
  • 將node安裝到其他盤的超詳細步驟與說明

    將node安裝到其他盤的超詳細步驟與說明

    基本現(xiàn)在很多主流的前端框架都用了node.js 但是node裝起來確實頭疼,下面這篇文章主要給大家介紹了關于如何將node安裝到其他盤的超詳細步驟與說明,需要的朋友可以參考下
    2023-06-06
  • 淺談Node異步編程的機制

    淺談Node異步編程的機制

    本篇文章主要介紹了淺談Node異步編程的機制,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • nodejs 使用nodejs-websocket模塊實現(xiàn)點對點實時通訊

    nodejs 使用nodejs-websocket模塊實現(xiàn)點對點實時通訊

    這篇文章主要介紹了nodejs 使用nodejs-websocket模塊實現(xiàn)點對點實時通訊的實例代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-11-11

最新評論