socket在egg中的使用實例代碼詳解
更新時間:2019年05月30日 14:26:35 作者:科比net
這篇文章主要介紹了socket在egg中的使用,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
config/config.default.js
exports.io = {
init: {},
namespace: {
'/': { //對應router.js里的 of('/')
connectionMiddleware: [ 'auth' ], //對應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中的使用實例代碼詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
javascript 定義初始化數(shù)組函數(shù)
有段javascript代碼很困惑,經(jīng)過不斷的查資料,終于弄懂了!呵呵!2009-09-09
javaScript讓文本框內(nèi)的最后一個文字的后面獲得焦點實現(xiàn)代碼
讓文本框內(nèi)的最后一個文字的后面獲得焦點,在應用中很常見,接下來提供解決方案,按興趣的朋友可以了解下2013-01-01
uni?app跨端自定義指令實現(xiàn)按鈕權(quán)限
這篇文章主要為大家介紹了uni?app跨端自定義指令實現(xiàn)按鈕權(quán)限詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12

