使用 Gradle 排除传递依赖
在 Gradle 中,使用应用程序插件生成 jar 文件时,可能会遇到传递依赖,您可能想要排除。为此,可以使用排除方法。
排除的默认行为
最初,尝试排除 org.slf4j:slf4j- 的所有实例log4j12 使用以下代码:
configurations { runtime.exclude group: "org.slf4j", name: "slf4j-log4j12" }
但是,这导致排除 所有 org.slf4j 工件,包括 slf4j-api。
自定义排除
要细化排除,可以利用组和模块属性:
configurations { runtime.exclude group: "org.slf4j", module: "slf4j-log4j12" }
此方法成功仅排除 org.slf4j:slf4j-log4j12,而不影响其他 slf4j
从单个依赖项中排除
如果需要排除特定依赖项,可以使用以下语法:
dependencies { compile ('org.springframework.data:spring-data-hadoop-core:2.0.0.M4-hadoop22') { exclude group: "org.slf4j", module: "slf4j-log4j12" } }
排除方法的限制
需要注意的是,虽然可以在排除中指定任意属性,但从单个依赖项中排除时不允许这样做。例如,以下代码将失败:
dependencies { compile ('org.springframework.data:spring-data-hadoop-core:2.0.0.M4-hadoop22') { exclude group: "org.slf4j", name: "slf4j-log4j12" } }
并显示以下错误消息:
No such property: name for class: org.gradle.api.internal.artifacts.DefaultExcludeRule
了解 Gradle 模块
在 Gradle 中,模块属性对应于Maven的artifactId。因此,要确定特定 Maven 工件的模块,请检查其artifactId。例如,Maven 工件 org.slf4j:slf4j-log4j12 将具有 slf4j-log4j12 的 Gradle 模块。
以上是如何在 Gradle 中排除特定的传递依赖?的详细内容。更多信息请关注PHP中文网其他相关文章!