socket在egg中的使用实例代码详解


Posted in Javascript onMay 30, 2019

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链接传过来的参数
 const rooms = [ room ];

 console.log(room, userId);

 const tick = (id, msg) => {
  logger.debug('#tick', id, msg);
  // 踢出用户前发送消息
  socket.emit(id, helper.parseMsg('deny', msg));
  // 调用 adapter 方法踢出用户,客户端触发 disconnect 事件
  nsp.adapter.remoteDisconnect(id, true, err => {
  logger.error(err);
  });
 };
 // 检查房间是否存在,不存在则踢出用户
 // 备注:此处 app.redis 与插件无关,可用其他存储代替
 
 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',{})//触发
  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;
};

总结

以上所述是小编给大家介绍的socket在egg中的使用实例代码详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript YUI 读码日记之 YAHOO.util.Dom - Part.4
Mar 22 Javascript
禁止页面刷新让F5快捷键及右键都无效
Jan 22 Javascript
JS案例分享之金额小写转大写
May 15 Javascript
JS自定义选项卡函数及用法实例分析
Sep 02 Javascript
深入学习Bootstrap表单
Dec 13 Javascript
canvas实现图像布局填充功能
Feb 06 Javascript
vue2.0移动端滑动事件vue-touch的实例代码
Nov 27 Javascript
如何根据业务封装自己的功能组件
Apr 19 Javascript
js使用cookie实现记住用户名功能示例
Jun 13 Javascript
浅谈TypeScript的类型保护机制
Feb 23 Javascript
vue+animation实现翻页动画
Jun 29 Javascript
基于小程序请求接口wx.request封装的类axios请求
Jul 02 Javascript
深入了解JavaScript 私有化
May 30 #Javascript
jQuery模拟html下拉多选框的原生实现方法示例
May 30 #jQuery
Vue CL3 配置路径别名详解
May 30 #Javascript
Vue CLI3中使用compass normalize的方法
May 30 #Javascript
通过实践编写优雅的JavaScript代码
May 30 #Javascript
AngularJs中$cookies简单用法分析
May 30 #Javascript
JS使用new操作符创建对象的方法分析
May 30 #Javascript
You might like
索尼ICF-SW100收音机评测
2021/03/02 无线电
php error_log 函数的使用
2009/04/13 PHP
php 模拟 asp.net webFrom 按钮提交事件的思路及代码
2013/12/02 PHP
ThinkPHP表单自动验证实例
2014/10/13 PHP
PHP实现防止表单重复提交功能【基于token验证】
2018/05/24 PHP
使用Math.floor与Math.random取随机整数的方法详解
2013/05/07 Javascript
javascript中对Attr(dom中属性)的操作示例讲解
2013/12/02 Javascript
jquery dialog open后,服务器端控件失效的快速解决方法
2013/12/19 Javascript
jQuery自带的一些常用方法总结
2014/09/03 Javascript
js实现简易的单数字随机抽奖(0-9)
2020/03/19 Javascript
浅析四种常见的Javascript声明循环变量的书写方式
2015/10/14 Javascript
快速解决jquery.touchSwipe左右滑动和垂直滚动条冲突
2016/04/15 Javascript
微信和qq时间格式模板实例详解
2016/10/21 Javascript
微信小程序  action-sheet详解及实例代码
2016/11/09 Javascript
jquery仿苹果的时间/日期选择效果
2017/03/08 Javascript
Angular4 反向代理Details实践
2018/05/30 Javascript
Vue不能检测到Object/Array更新的情况的解决
2018/06/26 Javascript
VUE脚手架的下载和配置步骤详解
2019/04/01 Javascript
js 将线性数据转为树形的示例代码
2019/05/28 Javascript
Vue列表循环从指定下标开始的多种解决方案
2020/04/08 Javascript
Python socket.error: [Errno 98] Address already in use的原因和解决方法
2014/08/25 Python
python遍历数组的方法小结
2015/04/30 Python
Python协程的用法和例子详解
2017/09/09 Python
pandas.dataframe中根据条件获取元素所在的位置方法(索引)
2018/06/07 Python
Python File(文件) 方法整理
2019/02/18 Python
用Python调用win命令行提高工作效率的实例
2019/08/14 Python
python自定义函数def的应用详解
2020/06/03 Python
前端canvas动画如何转成mp4视频的方法
2019/06/17 HTML / CSS
Gibson London官网:以地道的英国男装而著称
2019/12/06 全球购物
万代美国官网:PREMIUM BANDAI USA
2020/09/11 全球购物
Ruby如何创建一个线程
2013/03/10 面试题
大三学生入党思想汇报
2014/01/02 职场文书
如何写股份合作协议书
2014/09/11 职场文书
店铺转让协议书
2015/01/29 职场文书
硕士学位申请报告
2015/05/15 职场文书
新手入门Mysql--概念
2021/06/18 MySQL