项目脚手架 - 《Spring Boot + MyBatis + MyBatis Generator》
前言
最近启动了一个新的项目发现,每当一个新项目的启动往往需要从头搭建一个“框架”,其中虽然很多基础代码可以Copy,但也会浪费不少时间。
基于这个情况,我打算在GitHub上创建了一个公开库scaffold用来存放平时常用的脚手架项目。
脚手架仓库地址:https://github.com/majian159/scaffold
规划
实现的脚手架有:
- Java
- Spring Boot + MyBatis
规划的脚手架有:
- Java
- Spring Boot + JPA
- Spring Boot + MyBatis
- Web
- Ant design Pro
- antd
springboot-mybatis-scaffold
第一波因为项目需求先传了 基于 sb + mybatis 的脚手架,其实我个人更喜欢 sb + jpa + ddd 的脚手架,后续在整理出来。
介绍
这是一个基于 SpringBoot + MyBatis + MyBatis Generator 的脚手架项目。
脚手架默认实现了一个 department
RESTful API,用来演示。
脚手架集成内容
- Spring Boot
- Spring Security
- MyBatis
- MyBatis Generator
- PageHelper
- Swagger-UI
目录结构
scaffold
├── scaffold-api # REST API 模块
├── scaffold-common # 公共代码模块
└── scaffold-mbg # MyBatis Generator 及生成的内容
环境
- JDK8
- Lombok
脚手架配置
项目、程序包名称
使用 IDE 等工具进行批量全局替换。
Spring
- 开启 @Async 线程池使用
ForkJoinPool.commonPool()
@EnableScheduling
@EnableSwagger2
- datasource
- MySQL
- hikari
- 最小空闲连接 5
- 连接超时 15秒
- 最大连接池大小 20
- jackson
- 不包含 null 值的属性
MyBatis
- Mapper扫描路径
- 当前项目下的 dao/*.xml (项目中自定义的Mapper xml)
- 全局 mapper/*.xml (用于mbg生成的Mapper xml)
MBG
这边只是简化了
generatorConfig.xml
的配置,如有个性化需求可直接修改generatorConfig.xml
scaffold-mbg/src/main/resources/generator.properties
配置键 | 说明 | 默认值 |
---|---|---|
jdbc.driverClass | JDBC驱动类 | com.mysql.cj.jdbc.Driver |
jdbc.connectionURL | JDBC URL | jdbc:mysql://localhost/scaffold?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai |
jdbc.userId | 数据库用户名 | root |
jdbc.password | 数据库密码 | root |
common.basePackage | 基础的包名 | com.scaffold.springboot.mybatis.mbg |
common.basePath | 基础的路径 | scaffold-mbg |
Application
scaffold-api/src/main/resources/application.yml
配置键 | 说明 | 默认值 |
---|---|---|
application.basePackage | 基础 package,用来简化项目改名后带来的负担 | com.scaffold.springboot.mybatis |
RestControllerAdvice
当 Controller 抛出 ServiceException
, ApiException
异常时会经由 Advice 自动包装成 ApiErrorViewModel
, 并返回对应的 HttpStatusCode.
写在最后
这是一个高个人意愿的脚手架仓库,大家可以不用完全使用,只是参考部分内容,希望对大家有所帮助
脚手架仓库地址:https://github.com/majian159/scaffold
"阅读原文" 可直达 GitHub 库
如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!欢迎各位转载,转载文章之后须在文章页面明显位置给出作者和原文连接,谢谢。欢迎大家关注微信号。扫下面的二维码或者收藏下面的二维码关注吧(长按下面的二维码图片、并选择识别图中的二维码)

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)