nodejs結(jié)合socket.io實現(xiàn)websocket通信功能的方法
本文實例講述了nodejs結(jié)合socket.io實現(xiàn)websocket通信功能的方法。分享給大家供大家參考,具體如下:
因為項目中有需要實時獲取后臺數(shù)據(jù)的場景,之前一直是使用http心跳請求的方法。因為websocket與此模式相比有很大的性能提升,而且可以提高實時性,所以對websocket作了一些研究。這里是使用nodejs+socket.io來實現(xiàn)的。
達成目標(biāo)
將原來心跳請求后臺數(shù)據(jù)的方式,修改為通過socket連接后臺統(tǒng)一推送的方式。后臺的數(shù)據(jù)由別的進程寫入文件或?qū)懭雛edis,這里實現(xiàn)的是讀取文件的方式。
前期準(zhǔn)備
安裝nodejs(略)
服務(wù)器端
新建一個項目目錄,這里是sockettest
進入sockettest目錄,安裝express模塊和socketio模塊
npm install --save express@4.10.2 npm install --save socket.io
新建package.json文件,在其中寫入如下內(nèi)容:
{
"name": "socket-test",
"version": "0.0.1",
"description": "my first socket.io app",
"dependencies": {
"express": "^4.10.2",
"socket.io": "^1.7.2"
}
}
新建index.html,用于作為默認(rèn)的訪問顯示頁面,因為這里不會用到它,內(nèi)容隨意;
新建trends.js文件,在其中寫入內(nèi)容:
var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);
var fs = require('fs');
#默認(rèn)打開文件
app.get('/', function(req, res){
res.sendfile('index.html');
});
#用于存儲所有socket以廣播數(shù)據(jù)
var iolist = [];
#定義socket on connection(連入)事件行為
io.on('connection', function(socket){
#將連入socket加入列表
iolist.push(socket);
#記錄index,在disconnect(斷開連接)發(fā)生時將對應(yīng)的socket刪除
var sockex = iolist.indexOf(socket);
#定義on disconnect事件行為
socket.on('disconnect', function(){
#將斷開連接的socket從廣播列表里刪除
iolist.splice(sockex, 1);
});
});
# 數(shù)據(jù)廣播進程:每1秒鐘廣播一次
setInterval(function() {
# 如果沒有正在連接的socket,直接返回;
if (iolist.length <= 0) return;
var trends = fs.readFileSync('./data/trends.json','utf-8');#trends數(shù)據(jù)
var coins = fs.readFileSync('./data/coins.json','utf-8');#coins數(shù)據(jù)
#向所有socket連接發(fā)送數(shù)據(jù)
for (i in iolist) {
# 向客戶端發(fā)送trends數(shù)據(jù)
iolist[i].emit('trends', trends);
# 向客戶端發(fā)送coins數(shù)據(jù)
iolist[i].emit('coins', coins);
}
}, 1000);
# 服務(wù)器偵聽在sockettest.com的3000端口上
http.listen(3000, function(){
# 輸出到標(biāo)準(zhǔn)輸出
console.log('listening on sockettest.com:3000');
});
新建data目錄,并在下面新建兩個文件trends與coins,用于存放socket服務(wù)器將要讀取的數(shù)據(jù)。
新建public目錄,在其中新建一個文件index.html,文件內(nèi)容如下:
<!--引入必要的js文件-->
<script type="text/javascript" src="http://sockettest:3000/socket.io/socket.io.js"></script>
<script type="text/javascript">
//新建socket
var socket = io('http://sockettest.com:3000');
socketdata(socket);
function socketdata() {
#定義接收到coins類型數(shù)據(jù)時的行為
socket.on('coins', function(msg){
console.log(msg);
}
#定義接收到trends類型數(shù)據(jù)時的行為
socket.on('trends', function(msg){
console.log(msg);
}
}
</script>
代碼部署
剛才之所以要建兩個index.html文件,是為了能夠方便地在既有的web項目中使用nodejs提供的socket服務(wù)。這樣我們把public/index.html可以部署在別的服務(wù)器中,比如nginx或tomcat之類,然后在根目下啟動socket的服務(wù)器,為其提供socket服務(wù)。
首先在剛才的項目根目錄下執(zhí)行
node ./trends.js
并保持終端運行,然后再把項目部署在nginx里,通過chrome下訪問nginx提供的web服務(wù):
http://hostname/public/index.html
打開開發(fā)者模式,就能在console里看到每隔一秒便會收到來自node服務(wù)器的socket推送消息了。通過修改data目錄下的兩個文件,可以看到寫入到文件的數(shù)據(jù)也會實時地推送到客戶端這里來。
參考文章
http://socket.io/get-started/chat/
希望本文所述對大家nodejs程序設(shè)計有所幫助。
相關(guān)文章
通過NodeJS輕松使用GRPC和協(xié)議緩沖區(qū)的方法
本文介紹了GRPC和協(xié)議緩沖區(qū)的基本概念,并展示了如何在NodeJS應(yīng)用程序中使用它們,GRPC是一個高性能RPC框架,協(xié)議緩沖區(qū)則用于定義服務(wù)和序列化消息,本文給大家介紹如何在NodeJS應(yīng)用程序中使用GRPC和協(xié)議緩沖區(qū),感興趣的朋友一起看看吧2024-10-10
node-gyp安裝vuetify編譯失敗gyp?ERR的問題及解決
這篇文章主要介紹了node-gyp安裝vuetify編譯失敗gyp?ERR的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03
Nodejs實現(xiàn)爬蟲抓取數(shù)據(jù)實例解析
這篇文章主要介紹了Nodejs實現(xiàn)爬蟲抓取數(shù)據(jù)實例解析,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友參考下吧2018-07-07
nodejs+socket.io實現(xiàn)p2p消息實時發(fā)送的項目實踐
本文主要介紹了nodejs+socket.io實現(xiàn)p2p消息實時發(fā)送,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
node.js中實現(xiàn)token的生成與驗證的操作方法
Token是一種用于在客戶端和服務(wù)器之間安全傳輸信息的加密字符串,常用于身份驗證、授權(quán)、狀態(tài)管理和安全性,在Node.js中,常用jsonwebtoken庫生成和驗證Token,本文介紹node.js中實現(xiàn)token的生成與驗證的操作方法,感興趣的朋友一起看看吧2025-01-01
Nodejs訪問網(wǎng)絡(luò)并解析返回的json的實現(xiàn)方法
本文主要介紹了Nodejs訪問網(wǎng)絡(luò)并解析返回的json的實現(xiàn)方法,文中根據(jù)實例編碼詳細(xì)介紹的十分詳盡,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
三分鐘教會你用nodejs操作mysql數(shù)據(jù)庫
MySQL數(shù)據(jù)庫作為最流行的開源數(shù)據(jù)庫,基本上是每個web開發(fā)者必須要掌握的數(shù)據(jù)庫程序之一了,基本使用?node.js上,最受歡迎的mysql包就是mysql模塊,下面這篇文章主要給大家介紹了關(guān)于如何通過三分鐘教會你用nodejs操作mysql數(shù)據(jù)庫,需要的朋友可以參考下2023-05-05

