今天我在配置 sellercenter 的接口測試環境的時候,發現一些依賴的寫法不太一致:
比如有的依賴的<scope>是寫在子項目中的 <dependencies> 下的<dependency> 標簽中,
而有的依賴的<scope>是寫在父項目中的<dependencyManagement> 中 。
我知道前一種寫法是對的,而后一種寫法卻不知道對不對了,從網上查了下,沒有找到非常確切的答案,於是自己驗證了一把。
把驗證過程給大家說下,大家也可以自己練手。
首先新建三個項目,Parent作為父項目、projectA、projectB作為子項目。
在父項目Parent中依賴項如下:
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.8.1</version>
<scope>test</scope>
</dependency>
</dependencies>
在子項目projectA、projectB中沒有寫任何依賴,在projectA 下運行命令 mvn help:effective-pom,會發現A下面有 junit 4.8.1的依賴。
如果我把 父項目Parent 中的依賴修改如下:
<dependencyManagement>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.8.1</version>
<scope>test</scope>
</dependency>
</dependencies>
</dependencyManagement>
子項目ProjectA、projectB下面還是沒有任何依賴項,在projectA 下運行命令 mvn help:effective-pom,會發現A下面 沒有 junit 4.8.1的依賴。
如果我在projectA 下添加junit的依賴:
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
</dependency>
</dependencies>
再在projectA 下運行命令 mvn help:effective-pom,會發現A下面有了 junit 4.8.1的依賴,並且scope為 test。
那么經過驗證,scope寫在子項目中的<dependencies> 下的<dependency>中,或是寫在父項目中的<dependencyManagement>中,都是可以的。
但有一點需要注意,dependencies 和 dependencyManagement 的區別在於:
前者,即使在子項目中不寫該依賴項,那么子項目仍然會從父項目中繼承該依賴項。
后者,如果在子項目中不寫該依賴項,那么子項目中是不會從父項目繼承該依賴項的;只有在子項目中寫了該依賴項,才會從父項目中繼承該項,並且version 和 scope 都讀取自 父pom。
這樣做的目的是:
統一管理項目的版本號,確保應用的各個項目的依賴和版本一致,才能保證測試的和發布的是相同的成果,因此,在頂層pom中定義共同的依賴關系。同時可以避免在每個使用的子項目中都聲明一個版本號,這樣想升級或者切換到另一個版本時,只需要在父類容器里更新,不需要任何一個子項目的修改;如果某個子項目需要另外一個版本號時,只需要在dependencies中聲明一個版本號即可。子類就會使用子類聲明的版本號,不繼承於父類版本號。
區別
dependencies即使在子項目中不寫該依賴項,那么子項目仍然會從父項目中繼承該依賴項(全部繼承)
dependencyManagement里只是聲明依賴,並不實現引入,因此子項目需要顯示的聲明需要用的依賴。如果不在子項目中聲明依賴,是不會從父項目中繼承下來的;只有在子項目中寫了該依賴項,並且沒有指定具體版本,才會從父項目中繼承該項,並且version和scope都讀取自父pom;另外如果子項目中指定了版本號,那么會使用子項目中指定的jar版本。
