SpringBoot測試時卡在Resolving Maven dependencies的問題

測試時卡在Resolving Maven dependencies

有沒有遇到這個問題,在測試的時候

一直卡在Resolving Maven dependencies…

框內其實因為一直下載一個Junit5依賴的jar包,下載不下來所以卡死。

此時需要在pom中手動導入一下兩個依賴

    <dependency>
            <groupId>org.junit.platform</groupId>
            <artifactId>junit-platform-launcher</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <scope>test</scope>
        </dependency>

OK,完美解決! 

Maven項目缺少Maven Dependencies問題

今天搭建瞭一個maven項目

在pom.xml文件引入依賴後,發現項目結構中沒有Maven Dependencies文件(下圖),但是在java Build Path中又可以找到Maven Dependencies文件(如下圖):

但是,pom.xml文件中添加的依賴jar包也不會自動下載到項目中,update Project也是一樣,於是是網上查找瞭很多方法,嘗試後都發現沒有用,最終,查看自己的pom.xml文件,發現是在依賴前面寫瞭<dependencyManagement>這個標簽(下圖),查資料後發覺這個標簽的作用隻是聲明依賴,並不實現依賴的引入,因此,沒有jar包的引入,maven項目就不會顯示Maven Dependencies文件。

去掉這個標簽後,問題解決,maven Dependencies文件出現在maven項目中。

網上其他解決Maven Dependencies文件缺失的方法

第1種:Maven支持沒有打開:

這種情況一般是Eclipse自帶的Maven,或者自己裝的Maven並沒有打開服務。

解決方法:右鍵Maven項目–>Maven–>Enable Dependency Management

(可能有一些maven版本沒有Enable Dependency Management這個選項)

第2種:classpath文件問題或者.project文件問題:

解決方法:

(1)在.classpath文件中添加如下代碼:

<classpathentry kind="con" path="org.eclipse.m2e.MAVEN2_CLASSPATH_CONTAINER">
		<attributes>
			<attribute name="maven.pomderived" value="true"/>
			<attribute name="org.eclipse.jst.component.dependency" value="/WEB-INF/lib"/>
		</attributes>
	</classpathentry>

(2)在.project文件的<natures>中添加下面這行語句:

<nature>org.eclipse.m2e.core.maven2Nature</nature>

	<natures>
		<nature>org.eclipse.jem.workbench.JavaEMFNature</nature>
		<nature>org.eclipse.wst.common.modulecore.ModuleCoreNature</nature>
		<nature>org.eclipse.jdt.core.javanature</nature>
		<nature>org.eclipse.m2e.core.maven2Nature</nature>
		<nature>org.eclipse.wst.common.project.facet.core.nature</nature>
		<nature>org.eclipse.wst.jsdt.core.jsNature</nature>
	</natures>

第3種:項目–>properties–>Deployment Assembly–>Add–>java build path Entries–>Maven Dependencies–Finish

第4種:項目為非maven項目(情況較少)

解決方法:右鍵項目–>configure–>Convert to Maven Project

dependencyManagement與dependencies的區別

前面的出現問題主要是因為沒有弄清楚dependencyManagement與dependencies的區別,因此這部分主要總結pom.xml文件中這兩個標簽的區別:

1、DepencyManagement的應用場景:

當我們的項目模塊很多的時候,我們使用Maven管理項目非常方便,幫助我們管理構建、文檔、報告、依賴、scms、發佈、分發的方法。可以方便的編譯代碼、進行依賴管理、管理二進制庫等等。

由於我們的模塊很多,所以我們又抽象瞭一層,抽出一個itoo-base-parent來管理子項目的公共的依賴。為瞭項目的正確運行,必須讓所有的子項目使用依賴項的統一版本,必須確保應用的各個項目的依賴項和版本一致,才能保證測試的和發佈的是相同的結果。

在我們項目頂層的POM文件中,我們會看到dependencyManagement元素。通過它元素來管理jar包的版本,讓子項目中引用一個依賴而不用顯示的列出版本號。Maven會沿著父子層次向上走,直到找到一個擁有dependencyManagement元素的項目,然後它就會使用在這個dependencyManagement元素中指定的版本號。

來看看我們項目中的應用:  pom繼承關系圖:

itoo-base-parent(pom.xml)

<dependencyManagement>		
		<dependencies>
			<dependency>
				<groupId>org.eclipse.persistence</groupId>
				<artifactId>org.eclipse.persistence.jpa</artifactId>
				<version>${org.eclipse.persistence.jpa.version}</version>
				<scope>provided</scope>
			</dependency>
			
			<dependency>
				<groupId>javax</groupId>
				<artifactId>javaee-api</artifactId>
				<version>${javaee-api.version}</version>
			</dependency>
		</dependencies>
	</dependencyManagement>

itoo-base(pom.xml)

<!--繼承父類-->
<parent>
		<artifactId>itoo-base-parent</artifactId>
		<groupId>com.tgb</groupId>
 
		<version>0.0.1-SNAPSHOT</version>
		<relativePath>../itoo-base-parent/pom.xml</relativePath>
	</parent>
		<modelVersion>4.0.0</modelVersion>
		<artifactId>itoo-base</artifactId>
		<packaging>ejb</packaging>
		
		<!--依賴關系-->
		<dependencies>
		<dependency>
			<groupId>javax</groupId>
			<artifactId>javaee-api</artifactId>
		</dependency>
		
		<dependency>
			<groupId>com.fasterxml.jackson.core</groupId>
			<artifactId>jackson-annotations</artifactId>
		</dependency>
		
		<dependency>
			<groupId>org.eclipse.persistence</groupId>
			<artifactId>org.eclipse.persistence.jpa</artifactId>
			<scope>provided</scope>
		</dependency>
	</dependencies>
</project>

這樣做的好處:統一管理項目的版本號,確保應用的各個項目的依賴和版本一致,才能保證測試的和發佈的是相同的成果,因此,在頂層pom中定義共同的依賴關系。同時可以避免在每個使用的子項目中都聲明一個版本號,這樣想升級或者切換到另一個版本時,隻需要在父類容器裡更新,不需要任何一個子項目的修改;如果某個子項目需要另外一個版本號時,隻需要在dependencies中聲明一個版本號即可。子類就會使用子類聲明的版本號,不繼承於父類版本號。

2、Dependencies:

相對於dependencyManagement,所有聲明在dependencies裡的依賴都會自動引入,並默認被所有的子項目繼承。

3、區別:

(1)dependencies : 自動引入聲明在dependencies裡的所有依賴,並默認被所有的子項目繼承。如果項目中不寫依賴項,則會從父項目繼承(屬性全部繼承)聲明在父項目dependencies裡的依賴項。

(2)dependencyManagement : 這個標簽裡隻是聲明依賴,並不實現引入,因此子項目需要顯示的聲明需要用的依賴。如果不在子項目中聲明依賴,是不會從父項目中繼承下來的;隻有在子項目中寫瞭該依賴項,並且沒有指定具體版本,才會從父項目中繼承該項,並且version和scope都讀取自父pom;另外如果子項目中指定瞭版本號,那麼會使用子項目中指定的jar版本。

(3)dependencyManagement 中的 dependencies 並不影響項目的依賴項;而獨立dependencies元素則影響項目的依賴項。隻有當外層的dependencies元素中沒有指明版本信息時,dependencyManagement 中的 dependencies 元素才起作用。一個是項目依賴,一個是maven項目多模塊情況時作依賴管理控制的。

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: