一、dependencyManagement應(yīng)用場(chǎng)景
為了項(xiàng)目的正確運(yùn)行,必須讓所有的子模塊使用依賴項(xiàng)的統(tǒng)一版本,必須確保應(yīng)用的各個(gè)項(xiàng)目的依賴項(xiàng)和版本一致,才能保證測(cè)試的和發(fā)布的是相同的結(jié)果。在我們項(xiàng)目頂層的pom文件中,我們會(huì)看到dependencyManagement元素。通過它元素來管理jar包的版本,讓子項(xiàng)目中引用一個(gè)依賴而不用顯示的列出版本號(hào)。Maven會(huì)沿著父子層次向上走,直到找到一個(gè)擁有dependencyManagement元素的項(xiàng)目,然后它就會(huì)使用在這個(gè)dependencyManagement元素中指定的版本號(hào)。
父pom中dependencyManagement如下:
<modules>
<module>module1</module>
</modules>
<properties>
<spring-version>3.1.1.RELEASE</spring-version>
</properties>
<dependencyManagement>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring-version}</version>
</dependency>
</dependencyManagement>
子模塊module1
中dependency聲明如下所示:
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
</dependency>
</dependencies>
這樣做的好處:統(tǒng)一管理項(xiàng)目的版本號(hào),確保應(yīng)用的各個(gè)項(xiàng)目的依賴和版本一致,才能保證測(cè)試的和發(fā)布的是相同的成果,因此,在頂層pom中定義共同的依賴關(guān)系。同時(shí)可以避免在每個(gè)使用的子項(xiàng)目中都聲明一個(gè)版本號(hào),這樣想升級(jí)或者切換到另一個(gè)版本時(shí),只需要在父類容器里更新,不需要任何一個(gè)子項(xiàng)目的修改;如果某個(gè)子項(xiàng)目需要另外一個(gè)版本號(hào)時(shí),只需要在dependencies中聲明一個(gè)版本號(hào)即可。子類就會(huì)使用子類聲明的版本號(hào),不繼承于父類版本號(hào)。
二、dependencies應(yīng)用場(chǎng)景
相對(duì)于dependencyManagement,如果在父pom文件中中通過dependencies引入jar,將默認(rèn)被所有的子模塊繼承。
子模塊如果希望有自己個(gè)性化的內(nèi)容,可以在子模塊中對(duì)于其中的某個(gè)屬性進(jìn)重新定義。
例如:
父pom中:
<dependencyManagement>
<dependencies>
....
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>3.1</version>
</dependency>
....
</dependencies>
</dependencyManagement>
子模塊1的pod中:
<dependencies>
....
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>3.2</version>
<exclusions>
<exclusion>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
</exclusion>
</exclusions>
</dependency>
....
</dependencies>
那么,子模塊1由于重新定義了spring-web的描述,因此子模塊將采用自己的依賴定義,而不再使用pom中默認(rèn)定義的。
三、dependencyManagement與dependencies區(qū)別
dependencyManagement里只是聲明依賴,并不實(shí)現(xiàn)引入,因此子項(xiàng)目需要顯式的聲明需要用的依賴。如果不在子項(xiàng)目中聲明依賴,是不會(huì)從父項(xiàng)目中繼承下來的;只有在子項(xiàng)目中寫了該依賴項(xiàng),并且沒有指定具體版本,才會(huì)從父項(xiàng)目中繼承該項(xiàng),并且version和scope都讀取自父pom;另外如果子項(xiàng)目中指定了版本號(hào),那么會(huì)使用子項(xiàng)目中指定的jar版本。
dependencies即使在子模塊中不寫該依賴項(xiàng),那么子模塊仍然會(huì)從父項(xiàng)目中繼承該依賴項(xiàng)(全部繼承)。
在實(shí)際的項(xiàng)目開發(fā)中,推薦在父pom中使用dependencyManagement對(duì)項(xiàng)目中使用到的依賴包進(jìn)行統(tǒng)一的管理。