node.js中Socket.IO的進(jìn)階使用技巧
在上一篇博文Socket.IO中,我簡要介紹了Socket.IO的基本使用方法并創(chuàng)建了一個簡單的聊天室DEMO。本篇在入門篇的基礎(chǔ)上,繼續(xù)探討Socket.IO的進(jìn)階用法。本篇將從配置、房間、事件等方面入手,介紹一些Socket.IO中實用的API和注意事項。
1. 配置
Socket.IO提供了4個配置的API:io.configure, io.set, io.enable, io.disable。其中io.set對單項進(jìn)行設(shè)置,io.enable和io.disable用于單項設(shè)置布爾型的配置。io.configure可以讓你對不同的生產(chǎn)環(huán)境(如devlopment,test等等)配置不同的參數(shù)。以下定義了development和release兩種環(huán)境下Socket.IO的不同配置:
var io = require('socket.io').listen(80);
io.configure('development', function(){
io.enable('browser client etag');
io.set('log level', 1);
});
io.configure('release', function(){
io.set('transports', ['websocket']);
});
下面列舉一些常用的配置項,具體配置參數(shù)參見官方WIKI
1).transports(默認(rèn)['websocket', 'htmlfile', 'xhr-polling', 'jsonp-polling']):一個包含通信方法類型的數(shù)組。Socket.IO支持多種實現(xiàn)在線即時通信的方式,如websocket、polling等等,該配置能讓你自行選擇備用的通信方式。
2).log level(默認(rèn)3):日志輸出的最低級別,0為error,1為warn,2為info,3為debug,默認(rèn)即輸出所有類型的日志。
3).heartbeat interval(默認(rèn)25秒):心跳包發(fā)送間隔,客戶端需要在此時間段之內(nèi)向服務(wù)器發(fā)送一個心跳包才能保持通信。
2. 房間
房間是Socket.IO提供的一個非常好用的功能。房間相當(dāng)于為指定的一些客戶端提供了一個命名空間,所有在房間里的廣播和通信都不會影響到房間以外的客戶端。
在入門篇中,我們知道socket.join('room name')可用于客戶端進(jìn)入房間,socket.leave('room name')用于離開房間。當(dāng)客戶端進(jìn)入一個房間之后,可以通過以下兩種方式在房間里廣播消息:
//1. 向my room廣播一個事件,提交者會被排除在外(即不會收到消息)
io.sockets.on('connection', function (socket) {
//注意:和下面對比,這里是從客戶端的角度來提交事件
socket.broadcast.to('my room').emit('event_name', data);
}
//2. 向another room廣播一個事件,在此房間所有客戶端都會收到消息
//注意:和上面對比,這里是從服務(wù)器的角度來提交事件
io.sockets.in('another room').emit('event_name', data);
//向所有客戶端廣播
io.sockets.emit('event_name', data);
除了向房間廣播消息之外,還可以通過以下API來獲取房間的信息。
//獲取所有房間的信息
//key為房間名,value為房間名對應(yīng)的socket ID數(shù)組
io.sockets.manager.rooms
//獲取particular room中的客戶端,返回所有在此房間的socket實例
io.sockets.clients('particular room')
//通過socket.id來獲取此socket進(jìn)入的房間信息
io.sockets.manager.roomClients[socket.id]
3. 事件
Socket.IO內(nèi)置了一些默認(rèn)事件,我們在設(shè)計事件的時候應(yīng)該避開默認(rèn)的事件名稱,并靈活運用這些默認(rèn)事件。
服務(wù)器端事件:
1).io.sockets.on('connection', function(socket) {}):socket連接成功之后觸發(fā),用于初始化
socket.on('message', function(message, callback) {}):客戶端通過socket.send來傳送消息時觸發(fā)此事件,message為傳輸?shù)南ⅲ琧allback是收到消息后要執(zhí)行的回調(diào)
2).socket.on('anything', function(data) {}):收到任何事件時觸發(fā)
3).socket.on('disconnect', function() {}):socket失去連接時觸發(fā)(包括關(guān)閉瀏覽器,主動斷開,掉線等任何斷開連接的情況)
客戶端事件:
1).connect:連接成功
2).connecting:正在連接
3).disconnect:斷開連接
4).connect_failed:連接失敗
5).error:錯誤發(fā)生,并且無法被其他事件類型所處理
6).message:同服務(wù)器端message事件
7).anything:同服務(wù)器端anything事件
8).reconnect_failed:重連失敗
9).reconnect:成功重連
10).reconnecting:正在重連
在這里要提下客戶端socket發(fā)起連接時的順序。當(dāng)?shù)谝淮芜B接時,事件觸發(fā)順序為:connecting->connect;當(dāng)失去連接時,事件觸發(fā)順序為:disconnect->reconnecting(可能進(jìn)行多次)->connecting->reconnect->connect。
4. 授權(quán)
1).向所有客戶端廣播:socket.broadcast.emit('broadcast message');
2).進(jìn)入一個房間(非常好用!相當(dāng)于一個命名空間,可以對一個特定的房間廣播而不影響在其他房間或不在房間的客戶端):socket.join('your room name');
3).向一個房間廣播消息(發(fā)送者收不到消息):socket.broadcast.to('your room name').emit('broadcast room message');
4).向一個房間廣播消息(包括發(fā)送者都能收到消息)(這個API屬于io.sockets):io.sockets.in('another room name').emit('broadcast room message');
5).強制使用WebSocket通信:(客戶端)socket.send('hi'),(服務(wù)器)用socket.on('message', function(data){})來接收。
Socket.IO的進(jìn)階用法介紹基本就到這里。個人感覺在日常使用的時候這些基本API已經(jīng)夠用了,這也體現(xiàn)了Socket.IO極其簡潔易用的設(shè)計哲學(xué)。本文只是拋磚引玉,當(dāng)在實際運用中遇到解決不了的問題時,再去查看官方詳細(xì)的WIKI會比較好。
相關(guān)文章
Node.js中使用Buffer編碼、解碼二進(jìn)制數(shù)據(jù)詳解
這篇文章主要介紹了Node.js中使用Buffer編碼、解碼二進(jìn)制數(shù)據(jù)詳解,Buffer支持ascii、utf8、ucs2、base64等編碼格式,需要的朋友可以參考下2014-08-08從零開始學(xué)習(xí)Node.js系列教程四:多頁面實現(xiàn)數(shù)學(xué)運算的client端和server端示例
這篇文章主要介紹了Node.js多頁面實現(xiàn)數(shù)學(xué)運算的client端和server端,結(jié)合具體實例形式分析了nodejs客戶端提交與服務(wù)端處理實現(xiàn)數(shù)學(xué)運算的相關(guān)操作技巧,需要的朋友可以參考下2017-04-04async/await優(yōu)雅的錯誤處理方法總結(jié)
這篇文章主要給大家介紹了關(guān)于async/await優(yōu)雅的錯誤處理方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01基于nodejs使用express創(chuàng)建web服務(wù)器的操作步驟
express實際上是對nodejs內(nèi)置http進(jìn)行封裝后的第三方包,其中提供了快捷創(chuàng)建web服務(wù)器以及處理請求路由的方法,使我們可以更加方便快捷的實現(xiàn)一個web服務(wù)器項目,本文件給大家詳細(xì)介紹基于nodejs使用express?創(chuàng)建web服務(wù)器的操作步驟2023-07-07