egg.socket.io后端开发

2024-05-14 13:04
文章标签 开发 后端 io socket egg

本文主要是介绍egg.socket.io后端开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 安装egg-socket.io

npm i egg-socket.io@4.1.6 --save

最好指定egg-socket.io的版本号,比如我后端使用"egg-socket.io": "^4.1.6", 因为跟前端的socket.io-client是一一关联,socket.io-client用高版本或低版本,都不兼容了,可以查看egg-socket.io的依赖文件,比如在node_modules中可以看到客户端socket.io-client使用的版本号:

比如我前端安装依赖:

"socket.io-client": "^2.5.0",

2. config/plugin.js引入

io: {enable: true,package: 'egg-socket.io',},

 

3.配置socket.js

/config/config/socket.jsmodule.exports = config => {// socket.ioconfig.io = {init: {wsEngine: 'ws', //ws 引擎},namespace: {'/': {connectionMiddleware: [//'auth', 连接中间件],packetMiddleware: [],}},redis: {host: '127.0.0.1',port: 6379,auth_pass: '',db: 2,},}
}

4.在config.default.js引入

require('./config/socket')(config)//socket.io

5.使用路由,

/router/platform.js'use strict';module.exports = app => {const { router, controller, io } = app;//测试 这里的'test'跟前端的路由要保持一致io.of('/').route('test', io.controller.test.test)io.of('/').route('connenct',io.controller.notice.connenct)//router.get('/index', controller.home.index);};

6.先来看下egg-socket.io的项目目录结构

your-project-name
├── app
│   ├── extend
│   │   └── helper.js
│   ├── io
│   │   ├── controller
│   │   │   └── chat.js
│   │   └── middleware #插件中间件, 基于 socket 模型设计,处理 socket.io 请求 
│   │       ├── auth.js #对应刚才配置的connectionMiddleware: ['auth']
│   └── router.js
├── config
└── package.json

在app目录下新建io文件夹,io下新建controller

'use strict';const Controller = require('egg-cloud').Controller;/*** 测试socket*/class TestController extends Controller {async test() {const { ctx, app } = this;//测试连接 控制台自动输出//console.log("-------test--------")//前端传过来的参数let message = ctx.args[0];console.log(message);}}module.exports = TestController;

8. 使用知识

使用 emit() 方法发送事件: 通常用在后端,触发给前端,前端用on()接收

使用 on() 方法监听事件: 通常用在前端

9. 比如这里的路由是

//测试 这里的'test'跟前端的路由要保持一致io.of('/').route('test', io.controller.test.test)

10. 在前端怎么写呢?

actions: {//连接socketconnectSocket({ state, dispatch }) {const S = io('http://127.0.0.1:7001', {query: {},//可以传token参数transports: ['websocket'],timeout: 5000})//监听连接S.on('connect', () => {console.log("socket.io已连接")//测试推送一条消息S.emit('test', '123456')/触发给后端})//监听失败S.on('error', () => {state.socket = null})//监听断开S.on('disconnect', () => {state.socket = null})}}

后端的controller方法的test 就能收到

async test() {const { ctx, app } = this;//测试连接 控制台自动输出//console.log("-------test--------")//前端传过来的参数let message = ctx.args[0];console.log(message);}

这篇关于egg.socket.io后端开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/988805

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

Java 与 LibreOffice 集成开发指南(环境搭建及代码示例)

《Java与LibreOffice集成开发指南(环境搭建及代码示例)》本文介绍Java与LibreOffice的集成方法,涵盖环境配置、API调用、文档转换、UNO桥接及REST接口等技术,提供... 目录1. 引言2. 环境搭建2.1 安装 LibreOffice2.2 配置 Java 开发环境2.3 配

Python38个游戏开发库整理汇总

《Python38个游戏开发库整理汇总》文章介绍了多种Python游戏开发库,涵盖2D/3D游戏开发、多人游戏框架及视觉小说引擎,适合不同需求的开发者入门,强调跨平台支持与易用性,并鼓励读者交流反馈以... 目录PyGameCocos2dPySoyPyOgrepygletPanda3DBlenderFife

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁