socket在egg中的使用實例代碼詳解
config/config.default.js
exports.io = {
init: {},
namespace: {
'/': { //對應(yīng)router.js里的 of('/')
connectionMiddleware: [ 'auth' ], //對應(yīng)io/middleware/auth
packetMiddleware: [ 'filter' ],
},
},
};
config/plugin.js
exports.io = {
enable: true,
package: 'egg-socket.io',
};
router.js
io.of('/').route('chat', io.controller.chat.index);
io.of('/').route('message', io.controller.chat.message);
io.of('/').route('user:online', io.controller.chat.online);
app/io
app/io/middleware/auth.js
/**
* Created by bear on 2018/2/12.
*/
const PREFIX = 'room'; //定義房間號
module.exports = app => {
return async (ctx, next) => {
const { app, socket, logger, helper } = ctx;
const id = socket.id;
const nsp = app.io.of('/');
const query = socket.handshake.query;
// 用戶信息
const { room, userId } = query; //獲取socket鏈接傳過來的參數(shù)
const rooms = [ room ];
console.log(room, userId);
const tick = (id, msg) => {
logger.debug('#tick', id, msg);
// 踢出用戶前發(fā)送消息
socket.emit(id, helper.parseMsg('deny', msg));
// 調(diào)用 adapter 方法踢出用戶,客戶端觸發(fā) disconnect 事件
nsp.adapter.remoteDisconnect(id, true, err => {
logger.error(err);
});
};
// 檢查房間是否存在,不存在則踢出用戶
// 備注:此處 app.redis 與插件無關(guān),可用其他存儲代替
const hasRoom = await app.redis.get(`${PREFIX}:${room}`);
console.log(hasRoom,`${PREFIX}:${room}`)
// if (!hasRoom) {
// tick(id, {
// type: 'deleted',
// message: 'deleted, room has been deleted.',
// });
// return;
// }
// 用戶加入
logger.debug('#join', room);
socket.join(room);
// 在線列表
nsp.adapter.clients(rooms, (err, clients) => {
// 更新在線用戶列表
nsp.to(room).emit('online', {
clients,
action: 'join',
target: 'participator',
message: `User(${id}) joined.`,
});
console.log(123,clients)
});
// socket.emit('connect', 'packet received!');
await next();
console.log('disconnect!');
};
};
app/io/middleware/filter.js
module.exports = (app) => {
return async (ctx, next) => {
// console.log(ctx.packet);
await next();
// console.log('packet response!');
};
};
app/io/controller/chat.js
/**
* Created by bear on 2018/2/12.
*/
module.exports = app => {
class chatController extends app.Controller {
async index() {
this.ctx.socket.emit('res', 'test');
}
async message() { //方法通過 客戶端 this.emit('message',{})//觸發(fā)
this.ctx.socket.emit('message', 'test');
const params = this.ctx.args[0];
// this.ctx.service.message.sendPeerMessage(params);
console.log(2,params);
}
async online() {// modelMessage.sendOfflineMessage(socket, data.userId);
}
}
return chatController;
};
總結(jié)
以上所述是小編給大家介紹的socket在egg中的使用實例代碼詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
基于Web Audio API實現(xiàn)音頻可視化效果
這篇文章主要介紹了基于Web Audio API實現(xiàn)音頻可視化效果,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06
JavaScript實現(xiàn)數(shù)字?jǐn)?shù)組正序排列的方法
這篇文章主要介紹了JavaScript實現(xiàn)數(shù)字?jǐn)?shù)組正序排列的方法,涉及javascript中sort方法的使用技巧,非常具有實用價值,需要的朋友可以參考下2015-04-04
JavaScript筆記之?dāng)?shù)據(jù)屬性和存儲器屬性
本文給大家介紹js數(shù)據(jù)屬性和存儲器屬性,及兩種屬性的區(qū)別,對js數(shù)據(jù)屬性存儲器屬性相關(guān)知識感興趣的朋友一起學(xué)習(xí)2016-03-03
玩轉(zhuǎn)JavaScript OOP - 類的實現(xiàn)詳解
下面小編就為大家?guī)硪黄孓D(zhuǎn)JavaScript OOP - 類的實現(xiàn)詳解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06

