0

0

如何在 Gradle 多项目中实现子模块的传递性依赖

碧海醫心

碧海醫心

发布时间:2026-01-17 14:46:05

|

314人浏览过

|

来源于php中文网

原创

如何在 Gradle 多项目中实现子模块的传递性依赖

本文介绍如何通过 gradle 多项目结构(而非手动打包 jar)正确声明子项目依赖,使 projecta 中声明的 spring 等第三方依赖自动以传递方式生效于 projectb,避免重复声明和依赖缺失。

要让 GradleProjectB 自动继承 GradleProjectA 中定义的 Spring 依赖(即实现传递性依赖),关键在于将两个项目组织为 Gradle 多项目构建(multi-project build),而非独立项目 + 手动引入 JAR 包。JAR 方式默认不携带 compile 或 implementation 作用域的依赖信息,因此无法传递;而子项目依赖(project(':xxx'))则会完整解析其 dependencies 块,从而支持标准的依赖传递机制。

✅ 正确配置步骤

  1. 统一根目录,创建 settings.gradle
    在 ParentDirectory 根目录下新建 settings.gradle(或 settings.gradle.kts),声明子项目:

    // ParentDirectory/settings.gradle
    include ':GradleProjectA', ':GradleProjectB'
    ⚠️ 注意:项目名称必须与文件夹名严格一致(如 :GradleProjectA 对应 ParentDirectory/GradleProjectA/),否则同步失败。
  2. 在 GradleProjectB/build.gradle 中声明对 A 的依赖
    使用 implementation project(...) —— 这是启用传递性的核心:

    // GradleProjectB/build.gradle
    dependencies {
        implementation project(':GradleProjectA')
        // ✅ Spring 将自动从 GradleProjectA 传递进来
        // ❌ 不需要再写 implementation 'org.springframework:spring-core:6.1.0'
    }
  3. 确保 GradleProjectA 使用标准依赖声明
    其 build.gradle 应使用 implementation(而非 compile,已弃用)声明 Spring:

    // GradleProjectA/build.gradle
    dependencies {
        implementation 'org.springframework:spring-core:6.1.0'
        implementation 'org.springframework:spring-context:6.1.0'
        // 其他依赖...
    }

? 验证传递是否生效

运行以下命令检查依赖树:

cd ParentDirectory
./gradlew :GradleProjectB:dependencies --configuration runtimeClasspath

你将在输出中看到类似:

白瓜AI
白瓜AI

白瓜AI,一个免费图文AI创作工具,支持 AI 仿写,图文生成,敏感词检测,图片去水印等等。

下载
+--- project :GradleProjectA
|    +--- org.springframework:spring-core:6.1.0
|    \--- org.springframework:spring-context:6.1.0

这表明 Spring 依赖已成功由 ProjectA 传递至 ProjectB。

⚠️ 常见误区与注意事项

  • 不要用 flatDir 或 fileTree 引入 JAR:它们不解析 POM/Metadata,无法传递依赖;
  • 避免 api 误用:除非 ProjectB 需要 编译期使用 ProjectA 的 Spring 类型(如继承 Spring 注解类),否则 implementation project(...) 已足够且更安全;
  • 版本冲突时启用依赖约束:若多个子项目引入不同 Spring 版本,可在根 build.gradle 中统一管理:
    allprojects {
        configurations.all {
            resolutionStrategy {
                force 'org.springframework:spring-core:6.1.0'
            }
        }
    }

通过以上配置,Gradle 会将 ProjectA 视为一个“可传递的模块”,完整复用其依赖图谱,真正实现一次声明、处处可用的工程化协作。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

103

2025.08.06

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

9

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

32

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

14

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

42

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

6

2026.01.15

ps图片相关教程汇总
ps图片相关教程汇总

本专题整合了ps图片设置相关教程合集,阅读专题下面的文章了解更多详细内容。

9

2026.01.15

ppt一键生成相关合集
ppt一键生成相关合集

本专题整合了ppt一键生成相关教程汇总,阅读专题下面的的文章了解更多详细内容。

6

2026.01.15

php图片上传教程汇总
php图片上传教程汇总

本专题整合了php图片上传相关教程,阅读专题下面的文章了解更多详细教程。

2

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Django 教程
Django 教程

共28课时 | 3.2万人学习

Pandas 教程
Pandas 教程

共15课时 | 0.9万人学习

NumPy 教程
NumPy 教程

共44课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号