沐鸣娱乐


        SpringBoot版的低代码开发平台,关联无 SQL ,性能高10倍!(spring boot 低代码)

        SpringBoot版的低代码开发平台,关联无 SQL,性能高10倍!(spring boot 低代码)

        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-mobiles 移动端组件

        • 提供了配套的 diboot-mobiles-ui  ,内置了多种登录方式
        • 支持 账号密码登录 、微信小程序登录(自动注册)微信公众号登录(自动注册)

        diboot-core (diboot-core-starter) 使用步骤

        1. 引入依赖

        <dependency> <groupId>com.diboot</groupId> <artifactId>diboot-core-spring-boot-starter</artifactId> <version>{latestVersion}</version></dependency>

        Gradle:

        compile("com.diboot:diboot-core-spring-boot-starter:{latestVersion}")

        1. 配置参数(数据源)

        #datasource configspring.datasource.url=jdbc:mysql://localhost:3306/diboot_example?characterEncoding=utf8&serverTimezone=GMT+8spring.datasource.username=dibootspring.datasource.password=123456spring.datasource.hikari.maximum-pool-size=5spring.datasource.hikari.driver-class-name=com.mysql.cj.jdbc.Driver-------------------------------------------------------------------------#diboot-core-spring-boot-starter的可选参数配置:# 是否初始化sql,默认true ,初始化之后(或非开发环境)可以改为false关闭检测diboot.core.init-sql=false

        1. 配置config类

        diboot-core-starter 默认预置了 mybatis-plus 的分页配置(使用 mybatis-plus 3.4.x的 MybatisPlusInterceptor 最新配置方式)。如果您依赖的是core-starter,则无需再次配置 mybatis-plus 的分页。

        如果需要添加其他Interceptor ,则需要重新定义 MybatisPlusInterceptor 。示例如下:

        @Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() { MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); interceptor.addInnerInterceptor(new PaginationInnerInterceptor()); return interceptor;}//同时core-starter中也默认配置了HttpMessageConverters,如果需要更改默认配置, 则需要在配置类中重新定义HttpMessageConverters。@Beanpublic HttpMessageConverters jacksonHttpMessageConverters() { ...}

        注意 :diboot-core-starter 预置了默认的配置以及字典表相关的接口实现 ,如果是老项目中仅依赖 diboot-core(非diboot-core-starter),则还需要将 diboot 的包路径加入 ComponentScan 中

        diboot 新手体验

        在 IDE 中克隆 playground 项目

        "File -> New -> Project from version control…"菜单打开克隆项目对话框:

        SpringBoot版的低代码开发平台,关联无 SQL,性能高10倍!(spring boot 低代码)

        URL 中输入如下 playground 项目路径,指定项目本地路径(避免中文路径) ,点击 Clone 按钮 :https://gitee.com/dibo_software/playground.git

        SpringBoot版的低代码开发平台,关联无 SQL,性能高10倍!(spring boot 低代码)

        待克隆完成后,在右侧 Maven 视图中,添加 demo 项目下的 pom.xml

        SpringBoot版的低代码开发平台,关联无 SQL,性能高10倍!(spring boot 低代码)

        准备数据库后使用 devtools 初始化代码

        1 、点击控制台中打印出的 URL ,进入devtools操作页面。(个人用户初次使用需要扫码)

        2 、初次启动 devtools 会提示初始化组件的基础代码(为了方便自定义修改,devtools 将controller 等代码生成到本地项目中)。依次点击各组件的"生成代码"按钮 。

        SpringBoot版的低代码开发平台,关联无 SQL,性能高10倍!(spring boot 低代码)

        3、打开 demo 目录下的 java 目录,将会看到相关组件的初始化代码已生成。

        注意:如果启动前端发现验证码无法显示,则需要检查是否执行了这个步骤并重启了项目 。登录验证相关的 controller 需要此步骤中生成

        开源地址 :

        https://gitee.com/dibo_software/diboot

        原文链接:https://mp.weixin.qq.com/s/XYQ_0w0wtsKcLK0jvkdJIg

        相关新闻

        联系我们
        联系我们
        分享本页
        返回顶部

          XML地图