在我添加的示例 pom 中:
<dependencies>
<dependency>
<groupId>org.apache.openejb</groupId>
<artifactId>openejb-core</artifactId>
<version>4.7.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
然后运行:
mvn dependency:tree -Dincludes=org.slf4j
输出是:
[INFO] --- maven-dependency-plugin:2.8:tree (default-cli) @ test-junit ---
[INFO] com.sample:test-sample:jar:0.0.1-SNAPSHOT
[INFO] \- org.apache.openejb:openejb-core:jar:4.7.0:provided
[INFO] +- org.slf4j:slf4j-jdk14:jar:1.7.7:provided
[INFO] \- org.slf4j:slf4j-api:jar:1.7.7:provided
如您所见,Maven 与其official documentation 是一致的。您的屏幕截图中的问题可能出在您的 IDE 上。
表格是这个话题的重点:
从中我们可以看出,compile 或 runtime 范围内的可传递内容进入提供的范围内,provided 或 test 范围内的内容被忽略。
但是,如果我将示例 pom 更改为:
<dependencies>
<dependency>
<groupId>org.apache.openejb</groupId>
<artifactId>openejb-core</artifactId>
<version>4.7.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.7</version>
</dependency>
</dependencies>
然后重新运行依赖树命令,输出如下:
[INFO] --- maven-dependency-plugin:2.8:tree (default-cli) @ test-junit ---
[INFO] com.sample:test-sample:jar:0.0.1-SNAPSHOT
[INFO] +- org.apache.openejb:openejb-core:jar:4.7.0:provided
[INFO] | \- org.slf4j:slf4j-jdk14:jar:1.7.7:provided
[INFO] \- org.slf4j:slf4j-api:jar:1.7.7:compile
现在看:它不是作为提供的依赖项的子项,而是在同一级别。
让我们继续。
如果在我的示例 pom 中,我删除了 sl4f-api 依赖项,但我在 pom 中添加了以下内容:
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.7</version>
<scope>compile</scope>
</dependency>
</dependencies>
</dependencyManagement>
然后重新运行依赖树命令,我终于得到和你截图一样的了:
[INFO] --- maven-dependency-plugin:2.8:tree (default-cli) @ test-junit ---
[INFO] com.sample:test-sample:jar:0.0.1-SNAPSHOT
[INFO] \- org.apache.openejb:openejb-core:jar:4.7.0:provided
[INFO] +- org.slf4j:slf4j-jdk14:jar:1.7.7:provided
[INFO] \- org.slf4j:slf4j-api:jar:1.7.7:compile
Bingo:dependencyManagement 部分覆盖了传递依赖的范围,也影响了provided 范围的中介。这不是错误,它是设计使然,因为在本节中您定义了与依赖项相关的治理类型。这种情况下的图表也是正确的并且没有误导性,因为依赖关系仅由openejb-core 引入,然后受dependencyManagement 决定将sl4f-api 置于compile 范围内的影响。