
简洁优雅 · 稳定高效 | 宁静致远 · 精益求精
Dante Engine 基于 Spring Boot 3.X, 是 Dante Cloud 微服务架构内核核心组件库,可用于任何 Spring Boot 工程
Github 仓库 |
Gitee 仓库 |
文档
如果您觉得有帮助,请点右上角 "Star" 支持一下,谢谢!
企业级技术中台微服务架构与服务能力开发和管理平台
Dante Cloud 是国内首个支持阻塞式和响应式融合的微服务。以「高质量代码、低安全漏洞」为核心,采用领域驱动模型(DDD)设计思想,完全基于 Spring 生态全域开源技术和 OAuth2.1 协议,支持智能电视、IoT等物联网设备认证,满足国家三级等保要求、支持接口国密数字信封加解密、防刷、高防XSS和SQL注入等一系列安全体系的多租户微服务解决方案。
开源协议
因近期出现修改包名、删除作者版权信息、二次开源的行为,为保护作者权益,Dante Engine 自 3.3.X 版本开始,开源协议修改为 AGPL 3.0。点击【了解详情】

授权声明
本项目基于 GNU AFFERO GENERAL PUBLIC LICENSE Version 3 (AGPL V3) 开源协议,必须遵守以下补充条款。
- 不得将本软件应用于危害国家安全、荣誉和利益的行为,不能以任何形式用于非法为目的的行为。
- 对未经过授权或不遵循 AGPL 协议二次开源或者商业化我们将追究到底。
- 任何基于本软件而产生的一切法律纠纷和责任,均与作者无关。
使用说明
任何自用
(仅在内部使用不涉及商业化)修改 Dante Engine 源码使用公司,必须登记申请否则视为非法使用,留言登记默认合规。登记地址:在 https://gitee.com/dromara/dante-cloud/issues/I65F5B
项目特点
- 严格遵照“单一职责”原则,进行各个模块的划分和代码拆解。
- 严格遵循 Spring Boot 编码规则和命名规则。
- 大多数模块均支持 @EnableXXX注解 和 starter,让 Spring Bean 的注入顺序更加可控。
- 模块化设计思想,通过 Bean 注入、以及丰富的自定义 @ConditionalXXX 注解,让模块的添加和删除更加灵活。
- 各模块既可以综合在一起使用,也可以在其它 Spring Boot 工程中独立使用。
很多朋友不理解这样做的好处,明明很多代码都可以放在一起,为什么要拆分出这么多包、拆这么细?
这样做主要有以下优势:
- 虽然模块看似很多,但是每个模块职责单一、代码清晰,更有利于聚焦和定位问题。
- 通过对微服务架构的“庖丁解牛”,初学者不再需要在代码的海洋里“遨游”,通过针对性地了解各个模块,以点带面快速掌握微服务架构整体结构。
- 模块间的依赖极大的降低,想要替换为
Spring Authorization Server
,影响到的代码和范围将会很小。该工程也是使用 Spring Authorization Server
的前序工作
- 每个模块均是最小化依赖第三包,规避依赖包过度依赖,特别是 starter 过多依赖,导致不可预知、难以调试、不好修改等问题。
- 降低微服务系统代码量,独立组件可提前编译并上传至Maven仓库,降低工程代码编译耗时,改进 CICD 效率。
工程结构
dante-engine
├── dependencies -- 工程Maven顶级依赖,统一控制版本和依赖
├── engine-access -- 外部登录接入模块
├ ├── access-core -- 外部登录通用代码
├ ├── access-sdk-all -- 外部登录集成
├ ├── access-sdk-justauth -- JustAuth登录
├ ├── access-sdk-wxapp -- 微信小程序登录
├ ├── access-sdk-wxmpp -- 微信公众号登录
├ └── access-spring-boot-starter -- 外部登录 模块统一 Starter
├── engine-assistant -- 核心通用代码包
├ ├── assistant-core -- 核心通用代码
├ ├── assistant-sdk-ip2region -- IP离线定位组件核心代码模块
├ └── assistant-autoconfigure -- Assistant 模块统一 Starter
├── engine-cache -- 缓存模块
├ ├── cache-core -- 缓存通用代码
├ ├── cache-sdk-caffeine -- Caffeine 缓存配置相关代码模块
├ ├── cache-sdk-jetcache -- JetCache 相关代码模块
├ ├── cache-sdk-redis -- Redis 缓存配置相关代码模块
├ ├── cache-sdk-redisson -- Redisson 相关代码模块
├ └── cache-spring-boot-starter -- Cache 模块统一 Starter
├── engine-captcha -- 验证码模块
├ ├── captcha-core -- 验证码共性通用代码
├ ├── captcha-sdk-behavior -- 行为验证码(包括拼图滑块、文字点选)
├ ├── captcha-sdk-graphic -- 传统图形验证码(包括算数类型、中文类型、字母类型、GIF类型)
├ ├── captcha-sdk-hutool -- Hutool验证码(包括圆圈干扰、扭曲干扰、线段干扰)
├ └── captcha-spring-boot-starter -- Captcha 模块统一 Starter
├── engine-data -- 数据访问模块
├ ├── data-core -- 数据访问共性通用代码
├ ├── data-sdk-jpa -- JPA 及Hibernate 配置代码模块
├ ├── data-sdk-mybatis-plus -- MybatisPlus 相关代码模块
├ ├── data-sdk-tenant -- 基于JPA的多租户核心代码模块
├ └── data-spring-boot-starter -- Data 模块统一 Starter
├── engine-facility -- 微服务基础设施模块
├ ├── facility-alibaba-spring-boot-starter -- 面向 Spring Cloud Alibaba 的微服务基础设施适配模块
├ ├── facility-core -- 基础设施共性通用代码
├ ├── facility-gateway-spring-boot-starter -- Alibaba Sentinel 在 Gateway 环境下基础设施适配模块
├ ├── facility-original-spring-boot-starter -- 面向 Spring Cloud 原生全家桶的微服务基础设施适配模块
├ └── facility-tencent-spring-boot-starter -- 面向 Spring Cloud Tencent 的微服务基础设施适配模块
├── engine-message -- 消息模块
├ ├── message-core -- 消息共性通用代码
├ ├── message-kafka-spring-boot-starter -- 基础 Kafka 配置 Starter
├ ├── message-rabbitmaq-spring-boot-starter -- 基础 RabbitMQ 配置 Starter
├ ├── message-sdk-websocket -- 基于 WebSocket 的消息代码模块
├ └── message-spring-boot-starter -- Message 模块统一 Starter
├── engine-oauth2 -- OAuth2 认证模块
├ ├── oauth2-authorization-server-autoconfigure -- OAuth2 授权服务器基础内容自动配置模块
├ ├── oauth2-core -- OAuth2 共性通用代码模块
├ ├── oauth2-resource-server-autoconfigure -- OAuth2 资源服务器基础内容自动配置模块
├ ├── oauth2-sdk-authentication -- Spring Authorization Server 认证逻辑处理模块
├ ├── oauth2-sdk-authorization -- Spring Authorization Server 授权逻辑处理模块
├ ├── oauth2-sdk-data-jpa -- 基于 Spring Data JPA 封装的 Spring Authorization Server 数据访问代码模块
├ └── oauth2-sdk-management -- Spring Authorization Server 应用管理模块
├── engine-rest -- 服务Rest接口模块
├ ├── rest-core -- 服务 Rest 接口共性通用代码
├ ├── rest-sdk-condition -- 服务级 REST 相关自定义条件注解模块
├ ├── rest-sdk-protect -- 前后端数据加密、接口幂等、防刷、Xss 和 SQL 注入 Rest API 防护模块
├ ├── rest-sdk-service -- 基于 REST 的服务基础内容配置代码模块
├ ├── rest-spring-boot-starter -- Rest 模块统一 Starter(包括通用CRUD代码)
├ └── web-server-spring-boot-starter -- 基础 Web Server 配置模块
├── engine-sms -- 短信接入模块
├ ├── sms-core -- 短信共性通用代码模块
├ ├── sms-sdk-aliyun -- 阿里云短信发送模块
├ ├── sms-sdk-chinamobile -- 移动短信发送模块
├ ├── sms-sdk-huawei -- 华为短信发送模块
├ ├── sms-sdk-netease -- 网易短信发送模块
├ ├── sms-sdk-qiniu -- 七牛短信发送模块
├ ├── sms-sdk-tencent -- 腾讯短信发送模块
├ ├── sms-sdk-upyun -- 又拍短信发送模块
├ └── sms-spring-boot-starter -- SMS 模块统一 Starter
├── engine-supplier -- 应用支持模块
├ ├── supplier-sdk-message -- 消息功能支持模块
├ ├── supplier-sdk-upms-logic -- UPMS 基础服务支持模块
├ └── supplier-sdk-upms-rest -- UPMS 基础服务 REST 模块
└── readme -- README 相关素材放置目录
安全测试
Dante Cloud 已通过由第三方进行的软件出厂安全测试。详情参见:安全测试
阅读顺序
一、关联性阅读
部分组件存在关联和组合性,建议按照以下顺序阅读和了解代码:
- engine-assistant
- engine-cache
- engine-data
- engine-rest
- engine-oauth2
- engine-facility
- engine-message
二、独立性阅读
部分组件都是相对独立的,组件间的关联性非常弱。可分开独立阅读和了解代码:
- engine-access
- engine-captcha
- engine-supplier
技术解析
Dante Cloud 技术内幕高阶文档专栏(Cookbook)
因目前所使用的阅读产品支持度有限,想要购买阅读全文请点击对应文章链接,在电脑浏览器中打开后进行购买。购买后即可在小程序阅读全文,否则小程序端仅能阅读试读章节。
版本分支
一、版本号说明
本系统版本号,分为四段。
- 第一段和第二段,与 Spring Boot 版本对应,根据采用的 Spring Boot 版本变更。例如,当前采用 Spring Boot 2.4.6 版本,那么就以
2.4.X.X 开头
- 第三段,表示系统功能的变化
- 第四段,表示系统功能维护及优化情况
二、分支说明
分支名称 |
对应 Spring 生态版本 |
对应 JDK 版本 |
用途 |
现状 |
master |
Spring Boot 3.3 和 Spring Cloud 2023.0.1 |
JDK 17 |
主要发布分支 |
推荐使用代码分支 |
develop |
Spring Boot 3.3 和 Spring Cloud 2023.0.1 |
JDK 17 |
Development 分支 |
新功能、ISSUE 均以此分支作为开发,发布后会 PR 至 master 分支 |
3.1.X |
Spring Boot 3.1 和 Spring Cloud 2022.0.X |
JDK 17 |
历史版本,停止维护 |
基于 Spring Boot 3.1 时代开发的代码分支,稳定可用,不再维护 |
2.7.X |
Spring Boot 2.7 和 Spring Cloud 2021.0.X |
JDK 8 |
历史版本,停止维护 |
基于 Spring Boot 2.7 时代开发的代码分支,稳定可用,不再维护 |
参与贡献
- 在 Gitee fork 项目到自己的 repo
- 把 fork 过去的项目也就是你的项目 clone 到你的本地
- 修改代码(记得一定要修改 develop 分支)
- commit 代码,push 到自己的库(develop 分支)
- 登录 Gitee 在你首页可以看到一个 pull request 按钮,点击它,填写一些说明信息,然后提交即可。
- 等待维护者合并
交流反馈
- 欢迎提交ISSUE ,请写清楚问题的具体原因,重现步骤和环境
关联项目
赞助人列表
序号 |
赞助人 |
赞助时间 |
序号 |
赞助人 |
赞助时间 |
序号 |
赞助人 |
赞助时间 |
1 |
ご沉默菋噵 |
2021-10-25 |
2 |
偷土豆的人 |
2021-11-24 |
3 |
lorron |
2022-04-04 |
4 |
在云端 |
2022-12-26 |
5 |
西晽 |
2022-12-27 |
6 |
p911gt3rs |
2023-01-03 |
7 |
jacsty |
2023-01-31 |
8 |
hubert_rust |
2023-03-16 |
9 |
Zkey Z |
2023-03-18 |
10 |
志国欧巴 |
2023-03-27 |
11 |
michael |
2023-04-07 |
12 |
大叔丨小巷 |
2023-04-11 |
13 |
sun_left |
2023-04-19 |
14 |
time 丶 sand |
2023-07-06 |
15 |
印第安老斑鸠 |
2023-09-09 |
16 |
一阵风 |
2023-12-10 |
17 |
Jack |
2024-03-01 |
18 |
onehelper |
2024-05-24 |
19 |
宁哥 |
2024-05-29 |
20 |
|
|
21 |
|
|
简洁优雅 · 稳定高效 | 宁静致远 · 精益求精
Dante Engine 基于 Spring Boot 3.X, 是 Dante Cloud 微服务架构内核核心组件库,可用于任何 Spring Boot 工程
Github 仓库 | Gitee 仓库 | 文档
如果您觉得有帮助,请点右上角 "Star" 支持一下,谢谢!
企业级技术中台微服务架构与服务能力开发和管理平台
Dante Cloud 是国内首个支持阻塞式和响应式融合的微服务。以「高质量代码、低安全漏洞」为核心,采用领域驱动模型(DDD)设计思想,完全基于 Spring 生态全域开源技术和 OAuth2.1 协议,支持智能电视、IoT等物联网设备认证,满足国家三级等保要求、支持接口国密数字信封加解密、防刷、高防XSS和SQL注入等一系列安全体系的多租户微服务解决方案。
开源协议
授权声明
本项目基于 GNU AFFERO GENERAL PUBLIC LICENSE Version 3 (AGPL V3) 开源协议,必须遵守以下补充条款。
使用说明
任何
自用
(仅在内部使用不涉及商业化)修改 Dante Engine 源码使用公司,必须登记申请否则视为非法使用,留言登记默认合规。登记地址:在 https://gitee.com/dromara/dante-cloud/issues/I65F5B项目特点
很多朋友不理解这样做的好处,明明很多代码都可以放在一起,为什么要拆分出这么多包、拆这么细?
这样做主要有以下优势:
Spring Authorization Server
,影响到的代码和范围将会很小。该工程也是使用Spring Authorization Server
的前序工作工程结构
安全测试
Dante Cloud 已通过由第三方进行的软件出厂安全测试。详情参见:安全测试
阅读顺序
一、关联性阅读
部分组件存在关联和组合性,建议按照以下顺序阅读和了解代码:
二、独立性阅读
部分组件都是相对独立的,组件间的关联性非常弱。可分开独立阅读和了解代码:
技术解析
Dante Cloud 技术内幕高阶文档专栏(Cookbook)
版本分支
一、版本号说明
本系统版本号,分为四段。
二、分支说明
参与贡献
交流反馈
关联项目
赞助人列表