Skip to content

🎠 框架功能

功能框架及功能描述
前端项目采用 Vue3 + TypeScript + Ant Design Vue
后端项目结构采用模块化 + 插件化 + 扩展包形式,结构解耦、易于扩展
后端代码风格严格遵循《阿里巴巴编码规范》与项目统一配置的代码格式化
分布式注册中心采用 Alibaba Nacos
分布式配置中心采用 Alibaba Nacos
分布式网关中心采用 SpringCloud Gateway 框架扩展了多种功能
例如:内网鉴权、请求体缓存、跨域配置、请求响应日志等
负载均衡采用 SpringCloud Loadbalancer 扩展支持了开发团队路由 便于多团队开发调试
分布式服务保护分布式限流熔断采用 Alibaba Sentinel
RPC远程调用采用 全新 Apache Dubbo 3.x
分布式事务采用 Apache Seata
Web容器采用 Undertow 基于 XNIO 的高性能容器
权限认证采用 Sa-Token、Jwt 静态使用功能齐全,低耦合、高扩展
权限注解采用 Sa-Token 支持注解 登录校验、角色校验、权限校验、二级认证校验、HttpBasic校验、忽略校验
角色与权限校验支持多种条件 如AND OR权限 OR 角色等复杂表达式
第三方授权登录采用 JustAuth 第三方登录组件,支持微信、钉钉、飞书等数十种三方认证
关系数据库支持原生支持 MySQL、Oracle、PostgreSQL、SQLServer
可同时使用异构切换(支持其他 MyBatis-Plus 支持的所有数据库 只需要增加 JDBC 依赖即可使用 达梦金仓等均有成功案例)
分布式缓存支持 Redis 大部分新功能特性 如 分布式限流、分布式队列
Redis客户端采用 Redisson,Redis 官方推荐,基于 Netty 的客户端工具
支持Redis 90%以上的命令 底层优化规避很多不正确的用法 例如: keys被转换为scan
支持单机、哨兵、单主集群、多主集群等模式
缓存注解采用 Spring-Cache 注解 对其扩展了实现支持了更多功能
例如 过期时间 最大空闲时间 组最大长度等 只需一个注解即可完成数据自动缓存
ORM 框架采用 MyBatis-Plus 基于对象几乎不用写 SQL 全 Java 操作 功能强大插件众多
例如:多租户插件分页插件乐观锁插件
SQL 监控采用 P6Spy 可输出完整 SQL 与执行时间监控
数据分页采用 MyBatis-Plus 分页插件
框架对其进行了扩展 对象化分页对象 支持多种方式传参 支持前端多排序 复杂排序
数据权限采用 MyBatis-Plus 插件 自行分析拼接 SQL 无感式过滤
只需为 Mapper 设置好注解条件 支持多种自定义 不限于部门角色
数据脱敏采用 注解 + Jackson 序列化期间脱敏 支持不同模块不同的脱敏条件
支持多种策略 如身份证、手机号、地址、邮箱、银行卡等 可自行扩展
数据加解密采用 注解 + MyBatis 拦截器 对存取数据期间自动加解密
支持多种策略 如BASE64、AES、RSA、SM2、SM4等
接口传输加密采用 动态 AES + RSA 加密请求 body 每一次请求秘钥都不同大幅度降低可破解性
数据翻译采用 注解 + Jackson 序列化期间动态修改数据 数据进行翻译
支持多种模式:映射翻译 直接翻译 其他扩展条件翻译接口化两步即可完成自定义扩展 内置多种翻译实现
多数据源支持采用 dynamic-datasource 支持市面大部分数据库
通过yml配置即可动态管理异构不同种类的数据库 也可通过前端页面添加数据源
支持spel表达式从请求头参数等条件切换数据源
多数据源事务采用 dynamic-datasource 支持多数据源不同种类的数据库事务回滚
数据库连接池采用 HikariCP,Spring 官方内置连接池 配置简单 以性能与稳定性闻名天下
数据库主键采用 雪花ID 基于时间戳的 有序增长 唯一ID 再也不用为分库分表 数据合并主键冲突重复而发愁
WebSocket 实时通信基于 Spring 封装的 WebSocket 协议 扩展了Token鉴权与分布式会话同步 不再只是基于单机的废物
SSE 实时推送采用 Spring SSE 实现 扩展了Token鉴权与分布式会话同步
JSON 序列化采用 Jackson,Spring官方内置序列化
分布式幂等性(防重复提交)参考美团GTIS防重系统简化实现(细节可看文档)
分布式锁采用 Lock4j 底层基于 Redis Redisson
分布式任务调度采用 SnailJob 天生支持分布式 统一的管理中心 支持多种数据库 支持分片重试DAG任务流等
分库分表采用 Apache ShardingSphereShardingSphere-Proxy) 代理服务无入侵支持分库分表 只需编写分库分表规则即可 无
文件存储采用 MinIO 分布式文件存储 天生支持多机、多硬盘、多分片、多副本存储
支持权限管理 安全可靠 文件可加密存储
云存储采用 AWS S3 协议客户端 支持 七牛、阿里、腾讯 等一切支持S3协议的厂家
短信采用 SMS4J 短信聚合框架,支持数十余种第三方短信服务商 只需在 yml 配置好厂家密钥即可使用 可多厂家共用
邮件采用 mail-api 通用协议支持大部分邮件厂商
接口文档采用 SpringDoc、javadoc 无注解零入侵基于java注释
只需把注释写好 无需再写一大堆的文档注解了
校验框架采用 Hibernate Validator 支持注解与工具类校验 注解支持国际化
Excel导入导出采用 FastExcel(原Alibaba EasyExcel) 基于插件化
框架对其增加了很多功能 例如 自动合并相同内容 自动排列布局 字典翻译等
工作流支持支持中国式特色的各种复杂审批,会签、或签、票签、转办、委派、加减签等功能
工具类框架采用 Hutool、Lombok 上百种工具覆盖90%的使用需求,基于注解自动生成 Getter Setter 等简化框架大量代码
服务监控框架采用 SpringBoot-Admin 基于SpringBoot官方 actuator 探针机制
实时监控服务状态 框架还为其扩展了在线日志查看监控
可视化监控与告警采用 Prometheus、Grafana 多样化采集 多模板大屏展示 实时报警监控
链路追踪采用 Apache SkyWalking 实现分布式链路追踪
实时查看请求经过的每一处每一个节点
代码生成器只需设计好表结构 一键生成所有crud代码与页面
降低80%的开发量 把精力都投入到业务设计上
框架为其适配MP、SpringDoc规范化代码 同时支持动态多数据源代码生成
部署方式支持 Docker 编排 一键搭建所有环境 让开发人员从此不再为搭建环境而烦恼
项目路径修改提供详细的修改方案文档 并为其做了一些改动 非常简单即可修改成自己想要的
国际化基于请求头动态返回不同语种的文本内容 开发难度低 有对应的工具类 支持大部分注解内容国际化
代码单例测试提供单例测试 使用方式编写方法与maven多环境单测插件
Demo案例提供框架功能的实际使用案例 单独一个模块提供了很多很全