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

nodejs結(jié)合Socket.IO實(shí)現(xiàn)的即時(shí)通訊功能詳解

 更新時(shí)間:2018年01月12日 12:24:15   作者:孟海濱  
這篇文章主要介紹了nodejs結(jié)合Socket.IO實(shí)現(xiàn)的即時(shí)通訊功能,結(jié)合實(shí)例形式詳細(xì)分析了nodejs結(jié)合Socket.IO實(shí)現(xiàn)即時(shí)通訊的相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了nodejs結(jié)合Socket.IO實(shí)現(xiàn)的即時(shí)通訊功能。分享給大家供大家參考,具體如下:

動(dòng)態(tài)web

在html5以前,web的設(shè)計(jì)上并沒(méi)有考慮過(guò)動(dòng)態(tài),他一直是圍繞著文檔設(shè)計(jì)的,我們看以前比較老的網(wǎng)站,基本上都是某一刻用來(lái)顯示單一的文檔的,用戶請(qǐng)求一次web頁(yè)面,獲取一個(gè)頁(yè)面,但是隨著時(shí)間的推移,人們想要web做更多的事情了,而不是簡(jiǎn)單的要顯示文檔,而javaScript一直處于開(kāi)發(fā)人員推動(dòng)web頁(yè)面功能的發(fā)展中心。

Ajax無(wú)疑是動(dòng)態(tài)Web頁(yè)面的一個(gè)重大發(fā)展,他不再需要我們即使更新一點(diǎn)內(nèi)容,也需要刷新整個(gè)頁(yè)面了,但是有些方面,又體現(xiàn)了他的不足。如果從服務(wù)器請(qǐng)求數(shù)據(jù),他固然號(hào),但是如果服務(wù)器想要將數(shù)據(jù)推送到瀏覽器呢。Ajax技術(shù)無(wú)法很容易的支持將數(shù)據(jù)推送到客戶,雖然可以,但是需要跨國(guó)很多的障礙才行,而且不同的瀏覽器工作方式也不同,例如IE和FireBox他們的內(nèi)核就不一樣,從而工作方式也不一樣。

WebSocket是在對(duì)服務(wù)器和客戶端之間實(shí)現(xiàn)雙向通信問(wèn)題的相應(yīng)。他的思想是,從頭開(kāi)始,設(shè)計(jì)一個(gè)開(kāi)發(fā)人員可以使用的標(biāo)準(zhǔn)以便以一直的方式創(chuàng)建應(yīng)用程序,而不是通過(guò)復(fù)雜的,并不總能設(shè)置所有瀏覽器的工作。他的思想是Web服務(wù)器和瀏覽器之間保持持久打開(kāi),這就使得不管是服務(wù)器還是瀏覽器都可以在想要的時(shí)候推送數(shù)據(jù)。因?yàn)檫B接是持久的,所以數(shù)據(jù)的交換非常的快,也就成了實(shí)時(shí)的了。

Socket.IO

說(shuō)了那么多,我們介紹一下正主,Socket.IO是Node.js的一個(gè)模塊,他提供通過(guò)WebSocket進(jìn)行通信的一種簡(jiǎn)單方式,WebSocket協(xié)議很復(fù)雜,但是Socket.IO提供了服務(wù)器和客戶端雙方的組件,所以只需要一個(gè)模塊就可以給應(yīng)用程序加入對(duì)WebSocket的支持。而且還能支持不同的瀏覽器。

基礎(chǔ)的Socket.IO

Socket.IO既能在服務(wù)端也能在客戶端工作,要使用它,必須將其添加到服務(wù)器端的JavaScript(Node.js)和客戶端的JavaScript(JQuery)中,這是以為內(nèi)通信通常是雙向的,所以Sokcet.IO需要能在兩邊工作。

var server = http.createServer(function (req,res){
  fs.readFile('./index.html',function(error,data){
    res.writeHead(200,{'Content-Type':'text/html'});
    res.end(data,'utf-8');
  });
}).listen(3000,"127.0.0.1");
console.log('Server running at http://127.0.0.1:3000/');

而且必須將Socket.IO庫(kù)包含起來(lái),才能加入Socket.IO的功能。

var io = require('socket.io').listen(server);

然后加入一個(gè)事件來(lái)響應(yīng)客戶端到底是連接了,還是斷開(kāi)了。事件如下:

io.sockets.on('connection',function(socket){
  console.log('User connected');
  socket.on('disconnect',function(){
    console.log('User disconnected');
  });
});

是不是覺(jué)得非常的簡(jiǎn)單,下面我們看一下完整的代碼實(shí)現(xiàn)是如何實(shí)現(xiàn)的吧:

簡(jiǎn)單Socket.IO應(yīng)用

新建app.js

新建文件夾socket.io,在該文件夾下新建app.js,寫(xiě)如下代碼:

var http = require('http');
var fs = require('fs');
var server = http.createServer(function (req,res){
  fs.readFile('./index.html',function(error,data){
    res.writeHead(200,{'Content-Type':'text/html'});
    res.end(data,'utf-8');
  });
}).listen(3000,"127.0.0.1");
console.log('Server running at http://127.0.0.1:3000/');
var io = require('socket.io').listen(server);
io.sockets.on('connection',function(socket){
  console.log('User connected');
  socket.on('disconnect',function(){
    console.log('User disconnected');
  });
});

新建index.html

新建index.html文件,代碼如下:

<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8" />
  <title>Socket.IO Example</title>
 </head>
 <body>
  <h1>Socket.IO Example</h1>
  <script src="/socket.io/socket.io.js"></script>
  <script>
   var socket = io.connect('http://127.0.0.1:3000');
  </script>
 </body>
</html>

新建package.json

新建package.json來(lái)引入模塊。

{
  "name":"socketio_example",
  "version":"4.13.2",
  "private":true,
  "dependencies":{
    "socket.io":"1.4.5"
  }
}

版本號(hào)大家可以輸入自己的nodejs -V,或者socket.io -v來(lái)查看自己的版本號(hào)。

運(yùn)行

如果大家沒(méi)有安裝Socket.IO,可以運(yùn)行如下代碼,如果安裝了,自動(dòng)跳過(guò)這一步。

npm install socket.io

從終端運(yùn)行如下命令安裝模塊

npm install

運(yùn)行如下命令啟動(dòng)服務(wù)器

node app.js

打開(kāi)瀏覽器,輸入http://127.0.0.1:3000/,多打開(kāi)幾個(gè)頁(yè)簽,都輸入該網(wǎng)址,再任意關(guān)閉一個(gè)頁(yè)簽,然后看看我們的cmd命令窗口是不是如下:

這里會(huì)詳細(xì)的記錄又多少個(gè)用于連接了,也有多少個(gè)用戶斷開(kāi)連接了,這樣就能統(tǒng)計(jì)我們網(wǎng)頁(yè)的訪問(wèn)量了。

從服務(wù)器發(fā)送數(shù)據(jù)到客戶端

上邊的實(shí)例我們已經(jīng)實(shí)現(xiàn)了連接或者斷開(kāi)服務(wù)器做記錄了,但是我們要是想要推送消息怎么辦,例如我們好友的QQ上線了,騰訊都會(huì)咳嗽一下來(lái)提醒我們有好友上線。下面我們來(lái)做一下這個(gè)功能功能。

發(fā)送給單個(gè)用戶

io.sockets.on('connection',function(socket){
    socket.emit('message',{text:'你上線了'});
});

發(fā)給所有用戶

io.sockets.on('connection',function(socket){
    socket.broadcast.emit('message',{'你的好某XXX上線了'});
});

無(wú)論是發(fā)送給單個(gè)用戶還是所有用戶,這個(gè)message是自己寫(xiě)的,但是要在客戶端用,所以命名要注意。

客戶端

在客戶端我們可以添加偵聽(tīng)事件來(lái)接收數(shù)據(jù)。

var socket = io.connect('http://127.0.0.1:3000');
socket.on('message',function(data){
  alert(data.text);
})

通過(guò)這些功能,我們就在第一個(gè)例子的基礎(chǔ)上,實(shí)現(xiàn)用戶數(shù)量的統(tǒng)計(jì)。這里只需要在服務(wù)端設(shè)置一個(gè)變量,count,如果有一個(gè)上線,那么就數(shù)量+1,并通知所有用戶,最新的在線人數(shù)。

新建app.js

var http = require('http');
var fs = require('fs');
var count = 0;
var server = http.createServer(function (req,res){
  fs.readFile('./index.html',function(error,data){
    res.writeHead(200,{'Content-Type':'text/html'});
    res.end(data,'utf-8');
  });
}).listen(3000,"127.0.0.1");
console.log('Server running at http://127.0.0.1:3000/');
var io = require('socket.io').listen(server);
io.sockets.on('connection',function(socket){
  count++;
  console.log('User connected' + count + 'user(s) present');
  socket.emit('users',{number:count});
  socket.broadcast.emit('users',{number:count});
  socket.on('disconnect',function(){
    count--;
    console.log('User disconnected');
    socket.broadcast.emit('users',{number:count});
  });
});

創(chuàng)建index.html文件

<!DOCTYPE html>
<html>
 <head>
  <meta charset="utf-8" />
  <title>Socket.IO Example</title>
 </head>
 <body>
  <h1>Socket.IO Example</h1>
  <h2>How many users are here?</h2>
  <p id="count"></p>
   <script src="http://***.***.**.***:9001/jquery.min.js"></script>
  <script src="/socket.io/socket.io.js"></script>
  <script>
   var socket = io.connect('http://127.0.0.1:3000');
   var count = document.getElementById('count');
   socket.on('users',function(data){
    console.log('Got update from the server');
    console.log('There are ' + data.number + 'users');
    count.innerHTML = data.number
   });
  </script>
 </body>
</html>

創(chuàng)建package.json文件

{
  "name":"socketio_example",
  "version":"4.13.2",
  "private":true,
  "dependencies":{
    "socket.io":"1.4.5"
  }
}

安裝模塊npm install

啟動(dòng)服務(wù)器node app.js

打開(kāi)瀏覽器,輸入http://127.0.0.1:3000,可以看到如下圖片:

再打開(kāi)一個(gè)連接http://127.0.0.1:3000,可以看到如下結(jié)果:

可以看到如果我們打開(kāi)兩個(gè)連接,那么兩個(gè)頁(yè)簽都會(huì)顯示當(dāng)前又兩個(gè)用戶在線,如果關(guān)閉其中一個(gè),我們可以看到又顯示只有一個(gè)用戶在線。

將數(shù)據(jù)廣播給客戶端

接下來(lái)我們來(lái)看看Socket.IO是如何實(shí)現(xiàn)客戶端與客戶端的通信呢。
要想實(shí)現(xiàn)該功能,首先需要客戶端將消息發(fā)送到服務(wù)端,·然后服務(wù)端發(fā)送給除自己之外的其他客戶。服務(wù)器將消息發(fā)送給客戶端的方法在上一個(gè)例子中我們已經(jīng)實(shí)現(xiàn)了,那么我們需要的是客戶端把接收到的消息發(fā)送給服務(wù)器。

下邊的代碼思想是利用表單來(lái)實(shí)現(xiàn)的。

<form id="message-form" action="#">
   <textarea id="message" rows="4" cols="30"></textarea>
   <input type="submit" value="Send message" />
</form>
<script src="http://***.***.***.**:9001/jquery.min.js"></script>
<script src="/socket.io/socket.io.js"></script>
<script>
   var socket = io.connect('http://127.0.0.1:3000');
   var message = document.getElementById('message');
   $(message.form).submit(function() {
    socket.emit('message', { text: message.value });
    return false;
   });
   socket.on('push message', function (data) {
    $('form').after('<p>' + data.text + '</p>');
   });
</script>

實(shí)現(xiàn)的思想是,將JQuery和SocketIO庫(kù)包含進(jìn)來(lái),只是瀏覽器攔截127.0.0.1:3000的服務(wù),使用Jquery的submit方法加入偵聽(tīng)期,等候用戶提交表單。

發(fā)送消息給Socket>IO服務(wù)器,文本區(qū)域的內(nèi)容位消息發(fā)送。

添加return false ,防止表單在瀏覽器窗口提交。

在上邊已經(jīng)說(shuō)過(guò)服務(wù)器如何廣播消息,下邊我們說(shuō)一下客戶端如何顯示客戶端發(fā)送的消息。

socket.on('push message', function (data) {
  $('form').after('<p>' + data.text + '</p>');
})

實(shí)例實(shí)現(xiàn)

創(chuàng)建messaging的新文件夾

在文件夾下創(chuàng)建package.json文件,代碼如下:

{
  "name":"socketio_example",
  "version":"4.13.2",
  "private":true,
  "dependencies":{
    "socket.io":"1.4.5"
  }
}

創(chuàng)建app.js文件,代碼如下:

var http = require('http');
var fs = require('fs');
var server = http.createServer(function (req,res){
  fs.readFile('./index.html',function(error,data){
    res.writeHead(200,{'Content-Type':'text/html'});
    res.end(data,'utf-8');
  });
}).listen(3000,"127.0.0.1");
console.log('Server running at http://127.0.0.1:3000/');
var io = require('socket.io').listen(server);
io.sockets.on('connection',function(socket){
  socket.on('message',function(data){
    socket.broadcast.emit('push message',data);
  });
});

創(chuàng)建index.html

<!DOCTYPE html>
<html lang="en">
 <head>
  <meta charset="utf-8" />
  <title>Socket.IO Example</title>
 </head>
 <body>
  <h1>Socket.IO Example</h1>
  <form id="message-form" action="#">
   <textarea id="message" rows="4" cols="30"></textarea>
   <input type="submit" value="Send message" />
  </form>
  <script src="http://222.222.124.77:9001/jquery.min.js"></script>
  <script src="/socket.io/socket.io.js"></script>
  <script>
   var socket = io.connect('http://127.0.0.1:3000');
   var message = document.getElementById('message');
   $(message.form).submit(function() {
    socket.emit('message', { text: message.value });
    return false;
   });
   socket.on('push message', function (data) {
    $('form').after('<p>' + data.text + '</p>');
   });
  </script>
 </body>
</html>

加載模塊npm install

啟動(dòng)服務(wù)器node app.js

然后打開(kāi)瀏覽器的多個(gè)頁(yè)簽,都輸入http://127.0.0.1:3000

可以看到我們?cè)偃魏我粋€(gè)窗口輸入內(nèi)容,都會(huì)在其他的頁(yè)面顯示我們輸入的內(nèi)容,效果如下:

小結(jié)

這篇博客好長(zhǎng),其實(shí)說(shuō)了這么多,還是有很多的東西沒(méi)有說(shuō),但是我們還是討論了Socket.IO如何實(shí)現(xiàn)動(dòng)態(tài)的,通過(guò)服務(wù)端能顯示用戶的連接,和統(tǒng)計(jì)鏈接次數(shù)統(tǒng)計(jì),到最后的消息的通知和聊天功能的實(shí)現(xiàn)。在我們的生活中這種例子比比解釋?zhuān)鏠Q,例如淘寶的搶購(gòu),都是可以通過(guò)這種方式實(shí)現(xiàn)的,這樣我們就能實(shí)時(shí)的實(shí)現(xiàn)動(dòng)態(tài)的功能了。尤其是12306這個(gè)網(wǎng)站,我得和他們說(shuō)說(shuō)了,哈哈。

希望本文所述對(duì)大家nodejs程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • node.js實(shí)現(xiàn)多圖片上傳實(shí)例

    node.js實(shí)現(xiàn)多圖片上傳實(shí)例

    這篇文章主要介紹了node.js實(shí)現(xiàn)多圖片上傳實(shí)例,包括路由、控制器和視圖的源碼,重點(diǎn)在圖片上傳處理程序,需要的朋友可以參考下
    2014-06-06
  • node文件批量重命名的方法示例

    node文件批量重命名的方法示例

    本篇文章主要介紹了node文件批量重命名的方法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-10-10
  • 使用GruntJS構(gòu)建Web程序之合并壓縮篇

    使用GruntJS構(gòu)建Web程序之合并壓縮篇

    前一篇講述了如何使用concat和uglify命令實(shí)現(xiàn)JavaScript資源的合并,壓縮。這篇講述下css資源的合并和壓縮。
    2014-06-06
  • vscode執(zhí)行npm時(shí)的一些錯(cuò)誤以及處理辦法

    vscode執(zhí)行npm時(shí)的一些錯(cuò)誤以及處理辦法

    在前端開(kāi)發(fā)過(guò)程中,npm的使用是少不了的,所以需要知道基本的操作使用,并且了解常見(jiàn)的異常情況處理,下面這篇文章主要給大家介紹了關(guān)于vscode執(zhí)行npm時(shí)的一些錯(cuò)誤以及處理辦法的相關(guān)資料,需要的朋友可以參考下
    2022-07-07
  • 實(shí)戰(zhàn)node靜態(tài)文件服務(wù)器的示例代碼

    實(shí)戰(zhàn)node靜態(tài)文件服務(wù)器的示例代碼

    本篇文章主要介紹了實(shí)戰(zhàn)node靜態(tài)文件服務(wù)器的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • 淺談Node.js 沙箱環(huán)境

    淺談Node.js 沙箱環(huán)境

    本篇文章主要介紹了Node.js 沙箱環(huán)境 ,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-05-05
  • Nest.js中使用HTTP五種數(shù)據(jù)傳輸方式小結(jié)

    Nest.js中使用HTTP五種數(shù)據(jù)傳輸方式小結(jié)

    本文主要介紹了Nest.js中使用HTTP五種數(shù)據(jù)傳輸方式小結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Nodejs從有門(mén)道無(wú)門(mén)菜鳥(niǎo)起飛必看教程

    Nodejs從有門(mén)道無(wú)門(mén)菜鳥(niǎo)起飛必看教程

    下面小編就為大家?guī)?lái)一篇Nodejs從有門(mén)道無(wú)門(mén)菜鳥(niǎo)起飛必看教程。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-07-07
  • 詳解redis在nodejs中的應(yīng)用

    詳解redis在nodejs中的應(yīng)用

    本篇文章給大家詳細(xì)分析了redis在nodejs中的應(yīng),對(duì)此知識(shí)點(diǎn)有興趣的朋友可以跟著學(xué)習(xí)下。
    2018-05-05
  • node 使用 nodemailer工具發(fā)送驗(yàn)證碼到郵箱

    node 使用 nodemailer工具發(fā)送驗(yàn)證碼到郵箱

    最近閑著沒(méi)事,我就在練習(xí)使用node和mysql編寫(xiě)接口,計(jì)劃寫(xiě)一個(gè)完整的vue系統(tǒng),這篇文章主要介紹了node 使用 nodemailer工具發(fā)送驗(yàn)證碼到郵箱,需要的朋友可以參考下
    2023-10-10

最新評(píng)論