80

最近我一直在对前一段时间开发的一个项目进行一些改进,这就是我发现的。pom 文件中的许多依赖项都没有指定版本,但它们已被解决。该项目由 1 个根模块和 2 个子模块组成。使用了聚合器模式,这意味着根本没有依赖管理部分。上层项目只是聚合了 2 个模块,仅此而已。子项目不将其称为父项。他们有不同的父母。我无法理解的是,子项目本身和它们的父项目(事实上,它也没有dependencyManagement)都没有为某些依赖项指定版本。例如:

<dependency>
    <groupId>javax.mail</groupId>
    <artifactId>javax.mail-api</artifactId>
</dependency>
<dependency>
    <groupId>com.sun.mail</groupId>
    <artifactId>javax.mail</artifactId>
</dependency>
<dependency>
    <groupId>com.sun.mail</groupId>
    <artifactId>imap</artifactId>
</dependency>
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>jcl-over-slf4j</artifactId>
</dependency>
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>jul-to-slf4j</artifactId>
</dependency>
<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
</dependency>

有人可以帮我解决这个问题吗?maven 是否使用一些默认策略处理版本控制?什么是默认策略?

4

5 回答 5

44

好吧,我想我会自己回答。当然,我查看了依赖项:树,但我提到的所有依赖项都是树的第一级成员。我没有立即注意到的是,dependencyManagement它不存在于父模块中,但它存在于子模块中,更有趣的是它包含:

        <dependency>
            <groupId>io.spring.platform</groupId>
            <artifactId>platform-bom</artifactId>
            <version>1.0.2.RELEASE</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>

我以前从未使用过 Spring IO Platform,所以这对我来说是一个全新的概念。事实证明,该平台包含相当多的预配置依赖项: http: //docs.spring.io/platform/docs/current/reference/htmlsingle/#appendix-dependency-versions

于 2015-04-07T15:29:03.307 回答
27

如果不定义工件的版本,maven 是不可能工作的。它们应该在子模块或父模块中的dependencyManagement 标记中的某处定义。请检查您的 pom 层次结构。mvn help:effective-pom在项目的子模块目录中使用。您还可以使用mvn dependency:tree它来找出在依赖管理的结果中解决了哪些工件 - 以及包括版本号在内的完整工件信息。

于 2015-04-06T17:55:24.523 回答
5

利用

mvn -P<my_profile_of_interest> help:effective-pom -Dverbose

详细模式(自:3.2.0 起)添加了 XML 注释,其中包含对依赖声明来自的位置的精确引用。

于 2019-11-06T08:19:13.293 回答
5

pom 中定义的每个 maven 依赖项都必须直接或间接地具有一个版本,例如,通过 dependencyManagement 或 parent。话虽如此,如果没有给出版本,那么将使用dependencyManagement或父pom中提供的版本。

例如:在下面给出的 pom(只提到重要部分)中,没有为工件 jstl 提供任何版本。但是,在“mvn dependency:tree”中,它显示包含 jstl 版本 1.2。并查看 spring-boot-starter-parent,对于版本 2.3.3.RELEASE pom,它包括 jstl 版本 1.2。

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.3.3.RELEASE</version>
</parent>

<dependencies>
   ....
   <dependency>
       <groupId>javax.servlet</groupId>
       <artifactId>jstl</artifactId>
   </dependency>
   ....
</dependencies>
于 2020-09-02T22:39:21.760 回答
0

在我的情况下,如果我使用 Spring boot starter parent 来管理所有依赖项,并且lombok版本由 Spring boot 管理,那么这个问题是由于更高的java versionJAVA 11 造成的。我将 JAVA 8 导出到我的编译时环境中,使用 JAVA 8 后这个问题就消失了。

于 2022-02-26T07:31:14.230 回答