首頁 > 軟體

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

2022-02-16 13:00:32

測試時卡在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專案多模組情況時作依賴管理控制的。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com