🎠 框架功能
| 功能 | 框架及功能描述 |
|---|---|
| 前端项目 | 采用 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 ShardingSphere(ShardingSphere-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案例 | 提供框架功能的实际使用案例 单独一个模块提供了很多很全 |