dili-boss模块及功能范围: boss.diligrp.com boss-shared 基础设施和共享模块(解决循环依赖问题,工具类引入,中间件服务mq/redis/mysql等配置,第三方框架的封装和配置,全局异常拦截配置 ID生成器) boss-auth 用户认证授权,系统用户管理等 boss-admin 基础数据维护, 运营参数设置,帮助中心 boss-support 运营支持类功能:审核功能,用户数据查询 boss-report 运营数据报表 boss-ui 前端VUE页面 boss-boot 父工程(springboot打包,系统对外提供开放接口)
模块依赖: 后期根据实际需求调整模块依赖 boss-auth -> boss-shared boss-admin -> boss-auth boss-support -> boss-admin boss-report -> boss-admin boss-boot -> boss-admin boss-support boss-report
项目结构 com.diligrp.boss.xxxx - 模块spring配置xxxxConfiguration(Spring组件扫描配置/MybatisMapper扫描配置)ErrorCode Constants com.diligrp.boss.xxxx.controller - 后台接口 com.diligrp.boss.xxxx.api - 移动端接口 com.diligrp.boss.xxxx.service com.diligrp.boss.xxxx.dao com.diligrp.boss.xxxx.exception com.diligrp.boss.xxxx.domain com.diligrp.boss.xxxx.model com.diligrp.boss.xxxx.type com.diligrp.boss.xxxx.util resource/com.diligrp.boss.dao.mapper - mybatis mapper文件
系统对第三方系统提供接口通过erp-boot模块api包 模块内部后台服务接口使用controller包 所有数据模型类放入com.diligrp.boss.xxxx.model下,所有域模型类(VO DTO)放入com.diligrp.boss.xxxx.domain下 所有数据模型类须继承BaseDo类,进一步规范数据表设计:需包含id version created_time modified_time 所有枚举类型放入com.diligrp.boss.xxxx.type下,枚举类定义请提供code/name属性,参见com.diligrp.boss.shared.type.Gender 所有自定义工具类放入com.diligrp.boss.xxxx.util下,如果各模块共用则放erp-shared模块下 所有异常类继承PlatformServiceException(提供了错误码和是否打印异常栈信息功能),并放入com.diligrp.boss.xxxx.exception下 每个模块的常量类请放在模块根目录下,如通用常量请放入boss-shared模块下 错误码为6位,每个模块的错误类ErrorCode且放入模块根目录,错误码应唯一且独特如前三位为模块标识,公共错误码参见com.diligrp.boss.shared.ErrorCode
工具类 参见:com.diligrp.boss.shared.util.* com.diligrp.boss.shared.security.* 包括:JsonUtils CurrencyUtils DateUtils RandomUtils AssertUtils HexUtils AesCipher RsaCipher ShaCipher KeyStoreUtils等等
技术要求 JDK17 SpringCould SpringBoot 3版本 编译工具:gradle 第三方库尽量使用springboot默认推荐,如:Jackson Lettuce;springboot工具集中没有推荐的第三方库,引入时请在合适模块中进行 已在boss-shared中完成Jackson配置,包括Spring DataBinding,且额外提供了Jackson工具类JsonUtils 已在boss-shared中已完成Redis基础配置Lettuce,可直接使用StringRedisTemplate,如需进行进一步封装配置请在合适的模块中配置,如需Redis分布式锁,可考虑引入Redission 已在boss-shared中已完成Mybatis基础配置,使用MapperScan完成mapper文件的扫描,不用plus,可用mybatis分页插件 已在boss-shared中完成MQ基础配置RabbitMQ,可直接进行使用RabbitTemplate且可进行Queue Exchange和消息监听器的配置 外部第三方jar放入dili-boss/libs 新技术框架的引入不以个人熟悉为重点考量标准,以技术框架的通用型和稳定性为考量标准
数据库脚本要求 维护全量(dili-boss/scripts)和增量脚本(scripts/upgrade) 维护增量脚本,需同时修改全量脚本 所有建表SQL,每个字段需填写备注 通常情况下,每个表都需要包含三个字段id,version,created_time,modified_time 每个模块的数据表,建议统一的前缀boss_****
mkdir -p src/main/java/com/diligrp/erp/$ModuleName/api mkdir -p src/main/java/com/diligrp/erp/$ModuleName/controller mkdir -p src/main/java/com/diligrp/erp/$ModuleName/service mkdir -p src/main/java/com/diligrp/erp/$ModuleName/dao mkdir -p src/main/java/com/diligrp/erp/$ModuleName/exception mkdir -p src/main/java/com/diligrp/erp/$ModuleName/domain mkdir -p src/main/java/com/diligrp/erp/$ModuleName/model mkdir -p src/main/java/com/diligrp/erp/$ModuleName/type mkdir -p src/main/java/com/diligrp/erp/$ModuleName/util mkdir -p src/main/resources/com/diligrp/erp/dao/mapper