若依后台管理框架
若依后台管理框架是一套完整的前后台综合框架,包括前台页面和后台Java
,默认支持一常用的用户、角色、部门、岗位、菜单、权限、监控、定时任务等功能,还有强大的代码生成器,可以根据后台数据库表结构自动生成前后台代码。
1. 什么是若依后台管理
1.1 若依后台管理系统简介
若依后台管理框架是一套完整的前后台综合框架,使用到诸如SpringBoot
、Mybatis
、Druid
、thtmeleaf
、shiro
等等技术,支持前后端分析,具有基础功能完成,上手快速,扩展新功能简单等等优点。
若依官网:http://ruoyi.vip/
1.2 安装教程
开始若依后台管理框架只需要简单的三步即可:
- 克隆若依官方代码库;
- 初始化MySQL数据库脚本;
- 修改数据库连接信息。
1.3 代码结构
1 | com.ruoyi |
1.4 系统启动
若依后台管理系统是基于SpringBoot
,其启动类RuoYiApplication
为与ruoyi-admin
模块中,在跑完数据库脚本修改数据库连接信息后这,直接跑RuoYiApplication
里面的main
方法即可启动若依。
启动完成之后,在浏览器输入localhost
即可访问若依登录界面。默认用户名为admin
,密码admin123
。
2. 如何扩展自定义代码
若依拥有一个强大的代码自动生成模块,可以根据业务表结构自动生成前后台代码,极大的方便我们做功能扩展。
2.1 新建自定义子模块
因为若依标准后台是多模块结构,如果需要自定义功能,建议放在一个自定义的功能模块中,在RuoYi
工程里面新建一个Maven
子模块,确定GroupId,AtrifactId,name
等信息,这个步骤会因为IDE的不同而不同,但是都十分简单。
2.2 代码生成器的使用
- 在后台页面系统工具-代码生成-导入-选择数据库-确定。
- 点击单行数据编辑菜单,修改基本信息,字段信息,生成信息,保存,这里面配置的信息都会体现在最终生成的代码中。
- 点击生成代码,下载生成代码zip文件。
- 将自动生成的
java
和html
文件添加进自定义的模块中,这其中可能会需要修改包路径。
2.3 必要的配置修改
如果自定一的代码中有自定义包路径,那么就需要修改包扫描和mapper
扫描路径。
- 修改
mapper
扫描路径,Ruoyi-framework
工程com.ruoyi.framework.config
目录下面的ApplicationConfig
类上MapperScan
增加自定义mapper路径地址;
1 |
|
- 修改包扫描路径,
Ruoyi-admin
的RuoYiApplication
上面的SpringBootApplication
注解增加scanBasePackages
值。
1 | .class}, scanBasePackages = {"com.songwh.*", "com.ruoyi.*"}) (exclude = {DataSourceAutoConfiguration |
- 执行自动生成的脚本
2.4 修改菜单和权限
在执行玩自动生成的脚本后,会在后台增加新增功能的菜单,但是这些菜单的位置可能不符合自己的要求,这就需要自己在后台的菜单管理界面修改权限码菜单层级等功能。
3. 如何集成Mybatis plus
3.1 引入Mybatis plus
坐标
- 在
ruoyi
父工程引入Mybatis Plus
的坐标。
1 | <dependency> |
- 因为若依的
Mybatis
配置与Mybatis Plus
配置冲突,需要删除MyBatisConfig
配置类,或者将其@Configuration
注解删除。
3.2 修改类和对象适配Mybatis plus
- 修改自动生成的数据库模型对象,增加@
TableName
注解;
1 | "STOCK_MAIN_DATA_T") ( |
mapper
接口类扩展BaseMapper
接口;
1 | public interface StockDataDOMapper extends BaseMapper<StockDataDO> |
Service
接口扩展IService
接口
1 | public interface IStockDataDOService extends IService<StockDataDO> |
ServiceImpl
类扩展ServiceImpl
实现类
1 |
|
- Controller类扩展
BaseController
实现类
1 |
|
4. 如何实现多环境配置
4.1 多环境yml
配置文件
因为开发环境和生产环境的配置不一样,数据源配置,服务器端口配置等等都会配置不同的值,如果只有一个配置文件,面对不同的环境就需要频繁的修改,十分的不方便,而且还容易出错。而spring的profiles机制则可以很好的解决多环境配置问题。
实现方式也很简单,就是配置多个application-{profile}.yml
文件。将各个环境相同的配置放在application.yml
中,不同的配置分配配置在不同的文件中。
配置spring.profiles.active
参数,在选择不同的配置
4.2 启动命令增加spring.profiles.active
参数
如果是通过修改spring.profiles.active
的值来选择不同的环境配置,还是存在不同环境对应不同参数问题,为了实现同一个jar包适配不同的环境,可以在执行jar命令的时候增加一个参数:
1 | nohup java -jar ruoyi-admin.jar --spring.profiles.active=prod > 20200419-1.log & |