读书人

Maven中lt;dependenciesgt;节点跟lt;depende

发布时间: 2012-10-30 16:13:36 作者: rapoo

Maven中<dependencies>节点和<dependencyManagement>节点的区别

以前一直没有在意,今天建立maven工程的时候在<dependencyManagement>节点下加入了junit依赖,结果在dependency Graph中没有发现junit的依赖关系,怎么回事?没有加入项目依赖?遂google之

?

得解释:

1 .使用项目继承

利用项目继承可以将结构信息,部署信息,共同的依赖信息放置在单一的位置。在每个工程的pom中:

[...]

<parent>

<groupId>org.apache.maven.proficio</groupId>

<artifactId>proficio</artifactId>

<version>1.0-SNAPSHOT</version>

</parent>

[...]

这使得项目的pom可以继承顶层pom中的定义,检查顶层pom的dependencies部分:

<project>

[...]

<dependencies>

<dependency>

<groupId>junit</groupId>

<artifactId>junit</artifactId>

<version>3.8.1</version>

<scope>test</scope>

</dependency>

</dependencies>

[...]

</project>

在各个子模块的pom中没有对Junit依赖的定义,但是从顶层pom中继承了依赖的定义。

为了看清楚可以在一个子模块pom所在目录下,执行命令

#mvn help:effective-pom

可以看到最终起效果的pom,这在找错时很有效。

2.管理依赖

在pom中指明dependency management元素的方式maven结合项目继承来管理依赖。在多模块应用中,可能多个子项目会有共同的依赖。此时为了正确运行,必须让所有的子项目使用依赖项的同一版本。必须确保应用的各个项目的依赖项和版本一致,才能保证测试的和发布的是相同的成果。因此,应在顶层的pom中定义共同的依赖关系。

在Proficio应用的顶层pom中的dependency management段如下:

?<dependencyManagement>

???<dependencies>

?????<dependency>

???????<groupId>com.devzuz.mvnbook.proficio</groupId>

???????<artifactId>proficio-model</artifactId>

???????<c>${project.version}</version>

?????</dependency>

?????<dependency>

???????<groupId>com.devzuz.mvnbook.proficio</groupId>

???????<artifactId>proficio-api</artifactId>

???????<version>${project.version}</version>

?????</dependency>

?????<dependency>

???????<groupId>com.devzuz.mvnbook.proficio</groupId>

???????<artifactId>proficio-core</artifactId>

???????<version>${project.version}</version>

?????</dependency>

?????<dependency>

???????<groupId>com.devzuz.mvnbook.proficio</groupId>

???????<artifactId>proficio-store-memory</artifactId>

???????<version>${project.version}</version>

?????</dependency>

?????<dependency>

???????<groupId>com.devzuz.mvnbook.proficio</groupId>

???????<artifactId>proficio-store-xstream</artifactId>

???????<version>${project.version}</version>

?????</dependency>

?????<dependency>

???????<groupId>org.codehaus.plexus</groupId>

???????<artifactId>plexus-container-default</artifactId>

???????<version>1.0-alpha-9</version>

?????</dependency>

???</dependencies>

?</dependencyManagement>

注意${project.version}变量指的是应用的version。

顶层pom中的dependencies与dependencyManagement中的dependencies元素有一个重要的区别:

dependencyManagement中的dependencies元素只表明依赖项版本的优先选择,并不影响项目的依赖项;而dependencies元素则影响项目的依赖项。

检查Proficio api模块的pom:

<project>

?<parent>

???<groupId>com.devzuz.mvnbook.proficio</groupId>

???<artifactId>proficio</artifactId>

???<version>1.0-SNAPSHOT</version>

?</parent>

?<modelVersion>4.0.0</modelVersion>

?<artifactId>proficio-api</artifactId>

?<packaging>jar</packaging>

?<name>Proficio API</name>

?<dependencies>

???<dependency>

?????<groupId>com.devzuz.mvnbook.proficio</groupId>

??? ??<artifactId>proficio-model</artifactId>

???</dependency>

?</dependencies>

</project>

其中没有指明依赖项的版本信息,在顶层pom中的dependencyManagement中表明其优选的版本是${project.version}即1.0-SNAPSHOT。为使其模块pom完整,其版本信息会注入其中。只有当dependencies元素中没有指明版本信息时,dependencyManagement中的dependencies元素才起作用。

?

?

?

?

呵呵? 一个是项目依赖,一个是多模块maven项目时候的依赖管理控制的.

1 楼 kcai678 2010-07-05 两者的共同点,parent定义的依赖都会在子pom中继承。

两者的不同点在于:
如果在parent-pom中直接用:
<dependencies >
<dependency >
。。。
</dependency >
</dependencies > ,
那么在子pom中将只能被动的接受parent所定义的版本。

但是如果在parent-pom中用的是:
<dependencyManagement>
<dependencies >
<dependency >
。。。
</dependency >
</dependencies >
</dependencyManagement>
则留给了子pom一个可以更改物价版本的权利,而不必一定要继承parent所定义的版本。

不知道我的理解对不??呵呵 2 楼 lukeyang2000 2010-08-20 dependencyManagement 中的 dependencies 元素只表明依赖项版本的优先选择,并不影响项目的依赖项。所以Parent POM的有dependencyManagement 中的 dependencies 元素不会自动的加到child的dependencies 列表里。只有child里有同样的dependencies 时,才会被parent中dependencyManagement 中的 dependencies 元素所影响(主要是版本信息)。 3 楼 kaqike 2011-06-10 dependencies中的jar直接加到项目中,dependencyManagement 是对子项目中可能使用的依赖进行管理,本项目中可能并不使用这些依赖

读书人网 >其他相关

热点推荐