ruoyi-vue-pro 开发指南 ruoyi-vue-pro 开发指南
      视频教程
        微服务版 (opens new window)
        作者博客 (opens new window)
        GitHub (opens new window)
        • 萌新必读

          • 简介
          • 交流群
          • 视频教程
          • 功能列表
          • 快速启动(后端项目)
          • 快速启动(前端项目)
          • 接口文档
          • 技术选型
          • 项目结构
          • 代码热加载
          • 一键改包
          • 删除功能
          • 内网穿透
          • 达梦数据库专属
        • 后端手册

          • 新建模块
            • 代码生成【单表】(新增功能)
            • 代码生成【主子表】
            • 代码生成(树表)
            • 功能权限
            • 数据权限
            • 用户体系
            • 三方登录
            • OAuth 2.0(SSO 单点登录)
            • SaaS 多租户【字段隔离】
            • SaaS 多租户【数据库隔离】
            • WebSocket 实时通信
            • 异常处理(错误码)
            • 参数校验、时间传参
            • 分页实现
            • VO 对象转换、数据翻译
            • 文件存储(上传下载)
            • Excel 导入导出
            • 操作日志、访问日志、异常日志
            • MyBatis 数据库
            • MyBatis 联表&分页查询
            • 多数据源(读写分离)、事务
            • Redis 缓存
            • 本地缓存
            • 异步任务
            • 分布式锁
            • 幂等性(防重复提交)
            • 请求限流(RateLimiter)
            • 单元测试
            • 验证码
            • 工具类 Util
            • 配置管理
            • 数据库文档
          • 中间件手册

            • 定时任务
            • 消息队列(内存)
            • 消息队列(Redis)
            • 消息队列(RocketMQ)
            • 消息队列(RabbitMQ)
            • 消息队列(Kafka)
            • 限流熔断
          • 工作流手册

            • 工作流演示
            • 功能开启
            • 工作流(达梦适配)
            • 审批接入(流程表单)
            • 审批接入(业务表单)
            • 流程设计器(BPMN)
            • 流程设计器(钉钉、飞书)
            • 选择审批人、发起人自选
            • 会签、或签、依次审批
            • 流程发起、取消、重新发起
            • 审批通过、不通过、驳回
            • 审批加签、减签
            • 审批转办、委派、抄送
            • 执行监听器、任务监听器
            • 流程表达式
            • 流程审批通知
          • 大屏手册

            • 报表设计器
            • 大屏设计器
          • 支付手册

            • 功能开启
            • 支付宝支付接入
            • 微信公众号支付接入
            • 微信小程序支付接入
            • 支付宝、微信退款接入
          • 会员手册

            • 功能开启
            • 微信公众号登录
            • 微信小程序登录
            • 会员用户、标签、分组
            • 会员等级、积分、签到
          • 商城手册

            • 商城演示
            • 功能开启
            • 商城装修
            • 【商品】商品分类
            • 【商品】商品属性
            • 【商品】商品 SPU 与 SKU
            • 【商品】商品评价
            • 【交易】购物车
            • 【交易】交易订单
            • 【交易】售后退款
            • 【交易】快递发货
            • 【交易】门店自提
            • 【交易】分销返佣
            • 【营销】优惠劵
            • 【营销】拼团活动
            • 【营销】秒杀活动
            • 【营销】砍价活动
            • 【营销】满减送
            • 【营销】限时折扣
            • 【营销】内容管理
            • 【统计】会员、商品、交易统计
          • ERP手册

            • ERP 演示
            • 功能开启
            • 【产品】产品信息、分类、单位
            • 【库存】产品库存、库存明细
            • 【库存】其它入库、其它出库
            • 【库存】库存调拨、库存盘点
            • 【采购】采购订单、入库、退货
            • 【销售】销售订单、出库、退货
            • 【财务】采购付款、销售收款
          • CRM手册

            • CRM 演示
            • 功能开启
            • 【线索】线索管理
            • 【客户】客户管理、公海客户
            • 【商机】商机管理、商机状态
            • 【合同】合同管理、合同提醒
            • 【回款】回款管理、回款计划
            • 【产品】产品管理、产品分类
            • 【通用】数据权限
            • 【通用】跟进记录、待办事项
          • 公众号手册

            • 功能开启
            • 公众号接入
            • 公众号粉丝
            • 公众号标签
            • 公众号消息
            • 自动回复
            • 公众号菜单
            • 公众号素材
            • 公众号图文
            • 公众号统计
          • 系统手册

            • 短信配置
            • 邮件配置
            • 站内信配置
            • 数据脱敏
            • 敏感词
            • 地区 & IP 库
          • 运维手册

            • 开发环境
            • Linux 部署
            • Docker 部署
            • Jenkins 部署
            • HTTPS 证书
            • 服务监控
          • 前端手册 Vue 3.x

            • 开发规范
            • 菜单路由
            • Icon 图标
            • 字典数据
            • 系统组件
            • 通用方法
            • 配置读取
            • CRUD 组件
            • 国际化
            • IDE 调试
            • 代码格式化
          • 前端手册 Vue 2.x

            • 开发规范
            • 菜单路由
            • Icon 图标
            • 字典数据
            • 系统组件
            • 通用方法
            • 配置读取
          • 更新日志

            • 【v2.1.0】开发中
            • 【v2.0.1】2024-03-01
            • 【v2.0.0】2024-01-26
            • 【v1.9.0】2023-12-01
            • 【v1.8.3】2023-10-24
          • 开发指南
          • 后端手册
          芋道源码
          2022-03-02
          目录
          ?? 相关视频教程
          1. 新建 demo 模块
          2. 新建 demo-api 子模块
          3. 新建 demo-biz 子模块
          4. 新建 RESTful API 接口
          5. 引入 demo 模块
          6. 访问接口返回 404?
          7. 补充说明
          7.1 接口分组
          7.2 MyBatis 日志

          新建模块

          本章节,将介绍如何新建名字为 yudao-module-demo 的示例模块,并添加 RESTful API 接口。

          虽然内容看起来比较长,是因为艿艿写的比较详细,大量截图,保姆级教程!其实只有五个步骤,保持耐心,跟着艿艿一点点来。?? 完成之后,你会对整个 项目结构 有更充分的了解。

          # ?? 相关视频教程

          • 从零开始 06:如何 5 分钟,创建一个新模块? (opens new window)

          # 1. 新建 demo 模块

          ① 选择 File -> New -> Module 菜单,如下图所示:

          打开 New Module

          ② 选择 Maven 类型,并点击 Next 按钮,如下图所示:

          选择 Maven 类型

          ③ 选择父模块为 yudao,输入名字为 yudao-module-demo,并点击 Finish 按钮,如下图所示:

          填写 Module 信息

          ④ 打开 yudao-module-demo 模块,删除 src 文件,如下图所示:

          删除 src 文件

          ⑤ 打开 yudao-module-demo 模块的 pom.xml 文件,修改内容如下:

          提示

          <!-- --> 部分,只是注释,不需要写到 XML 中。

          <?xml version="1.0" encoding="UTF-8"?>
          <project xmlns="http://maven.apache.org/POM/4.0.0"
                   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
                   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
              <parent>
                  <artifactId>yudao</artifactId>
                  <groupId>cn.iocoder.boot</groupId>
                  <version>${revision}</version> <!-- 1. 修改 version 为 ${revision} -->
              </parent>
              <modelVersion>4.0.0</modelVersion>
          
              <artifactId>yudao-module-demo</artifactId>
              <packaging>pom</packaging> <!-- 2. 新增 packaging 为 pom -->
          
              <name>${project.artifactId}</name> <!-- 3. 新增 name 为 ${project.artifactId} -->
              <description> <!-- 4. 新增 description 为该模块的描述 -->
                  demo 模块,主要实现 XXX、YYY、ZZZ 等功能。
              </description>
          
          </project>
          

          # 2. 新建 demo-api 子模块

          ① 新建 yudao-module-demo-api 子模块,整个过程和“新建 demo 模块”是一致的,如下图所示:

          打开 New Module

          选择 Maven 类型

          填写 Module 信息

          ② 打开 yudao-module-demo-api 模块的 pom.xml 文件,修改内容如下:

          <?xml version="1.0" encoding="UTF-8"?>
          <project xmlns="http://maven.apache.org/POM/4.0.0"
                   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
                   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
              <parent>
                  <artifactId>yudao-module-demo</artifactId>
                  <groupId>cn.iocoder.boot</groupId>
                  <version>${revision}</version> <!-- 1. 修改 version 为 ${revision} -->
              </parent>
              <modelVersion>4.0.0</modelVersion>
              <artifactId>yudao-module-demo-api</artifactId>
              <packaging>jar</packaging> <!-- 2. 新增 packaging 为 jar -->
          
              <name>${project.artifactId}</name> <!-- 3. 新增 name 为 ${project.artifactId} -->
              <description> <!-- 4. 新增 description 为该模块的描述 -->
                  demo 模块 API,暴露给其它模块调用
              </description>
          
              <dependencies>  <!-- 5. 新增 yudao-common 依赖 -->
                  <dependency>
                      <groupId>cn.iocoder.boot</groupId>
                      <artifactId>yudao-common</artifactId>
                  </dependency>
              </dependencies>
          
          </project>
          

          ③ 【可选】新建 cn.iocoder.yudao.module.demo 基础包,其中 demo 为模块名。之后,新建 api 和 enums 包。如下图所示:

          新建基础包

          # 3. 新建 demo-biz 子模块

          ① 新建 yudao-module-demo-biz 子模块,整个过程和“新建 demo 模块”也是一致的,如下图所示:

          打开 New Module

          选择 Maven 类型

          填写 Module 信息

          ② 打开 yudao-module-demo-biz 模块的 pom.xml 文件,修改成内容如下:

          <?xml version="1.0" encoding="UTF-8"?>
          <project xmlns="http://maven.apache.org/POM/4.0.0"
                   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
                   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
              <parent>
                  <artifactId>yudao-module-demo</artifactId>
                  <groupId>cn.iocoder.boot</groupId>
                  <version>${revision}</version> <!-- 1. 修改 version 为 ${revision} -->
              </parent>
              <modelVersion>4.0.0</modelVersion>
              <packaging>jar</packaging> <!-- 2. 新增 packaging 为 jar -->
          
              <artifactId>yudao-module-demo-biz</artifactId>
          
              <name>${project.artifactId}</name> <!-- 3. 新增 name 为 ${project.artifactId} -->
              <description> <!-- 4. 新增 description 为该模块的描述 -->
                  demo 模块,主要实现 XXX、YYY、ZZZ 等功能。
              </description>
          
              <dependencies>  <!-- 5. 新增依赖,这里引入的都是比较常用的业务组件、技术组件 -->
                  <dependency>
                      <groupId>cn.iocoder.boot</groupId>
                      <artifactId>yudao-module-demo-api</artifactId>
                      <version>${revision}</version>
                  </dependency>
          
                  <!-- Web 相关 -->
                  <dependency>
                      <groupId>cn.iocoder.boot</groupId>
                      <artifactId>yudao-spring-boot-starter-web</artifactId>
                  </dependency>
          
                  <dependency>
                      <groupId>cn.iocoder.boot</groupId>
                      <artifactId>yudao-spring-boot-starter-security</artifactId>
                  </dependency>
          
                  <!-- DB 相关 -->
                  <dependency>
                      <groupId>cn.iocoder.boot</groupId>
                      <artifactId>yudao-spring-boot-starter-mybatis</artifactId>
                  </dependency>
          
                  <!-- Test 测试相关 -->
                  <dependency>
                      <groupId>cn.iocoder.boot</groupId>
                      <artifactId>yudao-spring-boot-starter-test</artifactId>
                  </dependency>
              </dependencies>
              
          </project>
          

          ③ 【必选】新建 cn.iocoder.yudao.module.demo 基础包,其中 demo 为模块名。之后,新建 controller.admin 和 controller.user 等包。如下图所示:

          新建基础包

          ④ 打开 Maven 菜单,点击刷新按钮,让引入的 Maven 依赖生效。如下图所示:

          刷新 Maven 依赖

          # 4. 新建 RESTful API 接口

          ① 在 controller.admin 包,新建一个 DemoTestController 类,并新建一个 /demo/test/get 接口。代码如下:

          package cn.iocoder.yudao.module.demo.controller.admin;
          
          import cn.iocoder.yudao.framework.common.pojo.CommonResult;
          import io.swagger.v3.oas.annotations.tags.Tag;
          import io.swagger.v3.oas.annotations.Operation;
          import org.springframework.validation.annotation.Validated;
          import org.springframework.web.bind.annotation.GetMapping;
          import org.springframework.web.bind.annotation.RequestMapping;
          import org.springframework.web.bind.annotation.RestController;
          
          import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
          
          @Tag(name = "管理后台 - Test")
          @RestController
          @RequestMapping("/demo/test")
          @Validated
          public class DemoTestController {
          
              @GetMapping("/get")
              @Operation(summary = "获取 test 信息")
              public CommonResult<String> get() {
                  return success("true");
              }
          
          }
          

          注意,/demo 是该模块所有 RESTful API 的基础路径,/test 是 Test 功能的基础路径。

          ① 在 controller.app 包,新建一个 AppDemoTestController 类,并新建一个 /demo/test/get 接口。代码如下:

          package cn.iocoder.yudao.module.demo.controller.app;
          
          import cn.iocoder.yudao.framework.common.pojo.CommonResult;
          import io.swagger.v3.oas.annotations.tags.Tag;
          import io.swagger.v3.oas.annotations.Operation;
          import org.springframework.validation.annotation.Validated;
          import org.springframework.web.bind.annotation.GetMapping;
          import org.springframework.web.bind.annotation.RequestMapping;
          import org.springframework.web.bind.annotation.RestController;
          
          import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
          
          @Tag(name = "用户 App - Test")
          @RestController
          @RequestMapping("/demo/test")
          @Validated
          public class AppDemoTestController {
          
              @GetMapping("/get")
              @Operation(summary = "获取 test 信息")
              public CommonResult<String> get() {
                  return success("true");
              }
          
          }
          

          在 Controller 的命名上,额外增加 App 作为前缀,一方面区分是管理后台还是用户 App 的 Controller,另一方面避免 Spring Bean 的名字冲突。

          可能你会奇怪,这里我们定义了两个 /demo/test/get 接口,会不会存在重复导致冲突呢?答案,当然是并不会。原因是:

          • controller.admin 包下的接口,默认会增加 /admin-api,即最终的访问地址是 /admin-api/demo/test/get
          • controller.app 包下的接口,默认会增加 /app-api,即最终的访问地址是 /app-api/demo/test/get

          # 5. 引入 demo 模块

          ① 在 yudao-server 模块的 pom.xml 文件,引入 yudao-module-demo-biz 子模块,并点击 Maven 刷新。如下图所示:

          刷新 Maven 依赖

          ② 运行 YudaoServerApplication 类,将后端项目进行启动。启动完成后,使用浏览器打开 http://127.0.0.1:48080/doc.html (opens new window) 地址,进入 Swagger 接口文档。

          ③ 打开“管理后台 - Test”接口,进行 /admin-api/demo/test/get 接口的调试,如下图所示:

          测试  接口

          ④ 打开“用户 App - Test”接口,进行 /app-api/demo/test/get 接口的调试,如下图所示:

          测试  接口

          # 6. 访问接口返回 404?

          请检查,你新建的模块的 package 包名是不是在 cn.iocoder.yudao.module 下!

          如果不是,修改 YudaoServerApplication (opens new window) 类,增加新建的模块的 package 包名。例如说:

          @SpringBootApplication(scanBasePackages = {"${yudao.info.base-package}.server", "${yudao.info.base-package}.module",
              "xxx.yyy.zzz"}) // xxx.yyy.zzz 是你新建的模块的 `package` 包名
          

          # 7. 补充说明

          # 7.1 接口分组

          如果你想 Swagger 有该模块的接口分组,则需要新建 GroupedOpenApi Bean。如下图所示:

          接口分组

          # 7.2 MyBatis 日志

          如果你希望新模块的 MyBatis 查询会打印 SQL 日志,需要在 logging.level 配置对应的 Logger。如下图所示:

          MyBatis 日志

          达梦数据库专属
          代码生成【单表】(新增功能)

          ← 达梦数据库专属 代码生成【单表】(新增功能)→

          Theme by Vdoing | Copyright © 2019-2024 芋道源码 | MIT License
            ×