SpringBoot版的低代码开发平台,关联无 SQL,性能高10倍!
diboot 的设计理念
Web 开发需要一个普适的基础框架,把复杂的问题简单化,最好还能做到更佳性能,规避常见的坑
程序员很难被替代,但程序员应该聚焦于数据结构设计、业务实现、难点解决,重复 CRUD 没啥长进
低代码是未来的趋势,CRUD 类重复有法则的工作是可以被自动化甚至被省掉的
diboot 主要技术栈
后端 Java + 关系数据库,跟紧 Spring 体系 (Spring Boot、Spring Cloud)
ORM 站队 Mybatis,通用 Mappe r框架选用 Mybatis-plus
权限: spring boo 版本使用 Shiro+JWT;spring cloud 版本使用 spring security + oauth2
前后分别,前端选型 Vue,支持 ElementUI 和 Antd vue pro
基于diboot-core的CRUD和常规关联的功能实现,代码量比传统Mybatis项目减少80%+,且性能更好更易保护。
diboot 基础组件
1、 diboot-core: 精简优化内核:写的更少,性能更好
主要特性:
单表CRUD无SQL
关联绑定无SQL(注解自动绑定)
数据字典无SQL(注解自动绑定)
跨表查询无SQL(自动构建QueryWrapper与查询)
BaseService扩展增强,支持常规的单表及关联开发场景接口
其他常用工具类、状态码、反常处理的更优实践封装
基于diboot-core的CRUD和常规关联的功能实现,代码量比传统Mybatis项目减少80%+,且性能更好更易保护。
2、IAM 身份认证基础组件 及 配套VUE前端框架(diboot-antd-admin、diboot-element-admin)
开箱即用的RBAC角色权限模型与预置组织人员岗位模型
基于无状态token的认证授权,支持刷新token
简化的BindPermission注解,支持兼容shiro的简化权限配置与自动鉴权
自动提取需要鉴权的后端接口, 借助前端功能方便配置菜单按钮权限
无缝适配redis,引进redis依靠即可启用shiro的redis缓存
支持基于注解的数据权限实现、简化的Log注解笔录操作日志等
支持灵巧的扩展能力(扩展多种登录方式、灵巧替换用户实体类、自定义缓存等)
3、diboot-file 文件相关处理组件
EasyExcel轻量封装,支持Java注解校验与@ExcelBind*注解实现字典及关联字段的name-value转换,并提供完美的校验错误提示
文件存储接口化,预置本地存储,简单扩展OSS、分布式存储等实现
封装常用的文件上传下载、图片压缩水印等常用处理
4、diboot-scheduler 定时任务组件
Quartz定时任务统一治理及日志的最佳实践封装
@CollectThisJob注解提供定时任务定义,自动收集供前端抉择
5、diboot-message 消息通知组件
通用的消息模板模板变量的设计方案
支持多通道的消息通知发送
6、diboot-mobile 移动端组件
提供了配套的 diboot-mobile-ui ,内置了多种登录方式
支持 账号密码登录、微信小程序登录(自动注册)微信公众号登录(自动注册)
diboot-core (diboot-core-starter) 使用步骤
dependency
groupIdcom.diboot/groupId
artifactIddiboot-core-spring-boot-starter/artifactId
version{latestVersion}/version
/dependency
或 Gradle:
compile("com.diboot:diboot-core-spring-boot-starter:{latestVersion}")
#datasource config
展开全文
spring.datasource.url=jdbc:mysql://localhost:3306/diboot_example?characterEncoding=utf8serverTimezone=GMT%2B8
spring.datasource.username=diboot
spring.datasource.password=123456
spring.datasource.hikari.maximum-pool-size=5
spring.datasource.hikari.driver-class-name=com.mysql.cj.jdbc.Driver
#diboot-core-spring-boot-starter的可选参数配置:
# 是否初始化sql,默认true,初始化之后(或非开发环境)可以改为false关闭检测
diboot.core.init-sql=false
diboot-core-starter 默认预置了 mybatis-plus 的分页配置(使用 mybatis-plus 3.4.x的 MybatisPlusInterceptor 最新配置方式)。假如您依靠的是core-starter,则无需再次配置 mybatis-plus 的分页。
假如需要添加其他Interceptor,则需要重新定义 MybatisPlusInterceptor。示例如下:
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
interceptor.addInnerInterceptor(new PaginationInnerInterceptor());
return interceptor;
//同时core-starter中也默认配置了。
@Bean
public () {
注重:diboot-core-starter 预置了默认的配置以及字典表相关的接口实现,假如是老项目中仅依靠 diboot-core(非diboot-core-starter),则还需要将 diboot 的包路径加进 ComponentScan 中
diboot 新手体验
在 IDE 中克隆 playground 项目
"File - New - Project from version control..."菜单打开克隆项目对话框:
图片
URL 中输进如下 playground 项目路径,指定项目本地路径(避免中文路径),点击 Clone 按钮 :
图片
待克隆完成后,在右侧 Maven 视图中,添加 demo 项目下的 pom.xml
图片
预备数据库后使用 devtools 初始化代码
1、点击掌握台中打印出的 URL,进进devtools操作页面。(个人用户初次使用需要扫码)
2、初次启动 devtools 会提示初始化组件的基础代码(为了方便自定义修改,devtools 将controller 等代码生成到本地项目中)。依次点击各组件的"生成代码"按钮。
图片
3、打开 demo 目录下的 java 目录,将会看到相关组件的初始化代码已生成。
注重:假如启动前端发现验证码无法展示,则需要检查是否执行了这个步骤并重启了项目。登录验证相关的 controller 需要此步骤中生成