v2.1版本发布,可以告别常规SQL和CRUD了! B站上手视频 、 playground新手体验包
设计目标:面向开发人员的低代码开发平台,将重复性的工作自动化,提高质量、效率、可维护性。
diboot v2版本,目前实现: diboot-core高效内核 + diboot-devtools开发助理 + IAM身份认证、file文件处理等基础组件 + diboot-*-admin基础后台。
高效精简内核,重构查询方式(拆解关联查询,程序中Join),简化开发,主要实现:
基于Mybatis-Plus实现(Mybatis-Plus具备通用Mapper方案和灵活的查询构造器)
扩展实现了多表关联查询的无SQL方案,只需要一个简单注解@Bind*,就可以实现关联对象(含字段、字段集合、实体、实体集合等)的数据绑定,且实现方案是将关联查询拆解为单表查询,保障最佳性能。
通过@BindDict注解实现数据字典(枚举)的存储值value与显示值name的转换。
@BindQuery注解绑定字段查询方式及关联表,自动构建QueryWrapper,并动态执行单表或Join联表查询。
createEntityAndRelatedEntities、getValuesOfField、exists、getKeyValueList、getViewObject*等接口
JsonResult、字符串处理、常用校验、BeanUtils、DateUtils等
基于diboot-core 2.x版本的CRUD和简单关联的常规功能实现,代码量比传统Mybatis项目减少80%+),且实现更高效更易维护。
更多介绍请查看: diboot-core README.
- 使用简单(UI界面操作,引入依赖配置参数后,即可随SpringBoot本地项目启动运行)
- 功能很强大:
- 单表与关联场景CRUD导入导出的完整功能全自动生成,无需手写代码
- 数据结构变更与代码联动同步,自动记录变更SQL、维护索引
- 一键生成代码&非覆盖式更新本地后端代码
- 配置很灵活(可按需配置生成代码路径,是否启用
Lombok
、Swagger
等) - SQL与代码很标准(devtools标准化了数据结构定义与代码实现)
- 支持多数据库(MySQL、MariaDB、ORACLE、SQLServer、PostgreSQL)
- RBAC角色权限模型 + JWT的认证授权 实现,支持刷新token
- 简化的BindPermission注解,支持兼容shiro的简化权限绑定与自动鉴权
- 自动提取需要验证的后端接口, 借助前端功能方便绑定前后端菜单按钮权限
- 支持基于注解的数据权限实现
- 支持灵活的扩展能力(扩展多种登录方式、灵活替换用户实体类、自定义缓存等)
更多介绍请查看: iam-base-starter README.
- EasyExcel轻量封装,支持Java注解校验与@ExcelBind*注解实现字典及关联字段的name-value转换,并提供完善的校验错误提示
- 封装常用的文件本地存储、上传下载、图片压缩水印等常用处理
更多介绍请查看: diboot-file-starter README.
其他组件逐步开发中 ...
感谢JetBrains提供Open Source license,JetBrains IDEA 是最好的Java IDE。
如果您有技术问题,欢迎加群交流:
QQ群: 731690096
微信群(备注diboot)加: wx20201024