maven dependency中scope=compile 和 provided區別

轉自:http://supercharles888.blog.51cto.com/609344/981316

問題再現:

上次這邊朋友問我一個問題,就是他們在pom.xml中的dependency中,看到有一些是<scope>provided</scope>的情況,比如如下:

  1. <dependency> 
  2.    <groupId>com.liferay.portal</groupId> 
  3.    <artifactId>portal-impl</artifactId> 
  4.    <version>6.1.0</version> 
  5.    <scope>provided</scope> 
  6. </dependency> 

他們問我scope在何種情況下要設置爲provided,以及和scope設置爲compile的區別。

 

解釋:

其實這個問題很簡單。

對於scope=compile的情況(默認scope),也就是說這個項目在編譯,測試,運行階段都需要這個artifact對應的jar包在classpath中。

而對於scope=provided的情況,則可以認爲這個provided是目標容器已經provide這個artifact。換句話說,它隻影響到編譯,測試階段。在編譯測試階段,我們需要這個artifact對應的jar包在classpath中,而在運行階段,假定目標的容器(比如我們這裏的liferay容器)已經提供了這個jar包,所以無需我們這個artifact對應的jar包了。

 

聽起來很玄乎,對吧,其實一點也不難理解。舉個scope=provided的例子。

比如說,假定我們自己的項目ProjectABC 中有一個類叫C1,而這個C1中會import這個portal-impl的artifact中的類B1,那麼在編譯階段,我們肯定需要這個B1,否則C1通不過編譯,因爲我們的scope設置爲provided了,所以編譯階段起作用,所以C1正確的通過了編譯。測試階段類似,故忽略。

那麼最後我們要吧ProjectABC部署到Liferay服務器上了,這時候,我們到$liferay-tomcat-home\webapps\ROOT\WEB-INF\lib下發現,裏面已經有了一個portal-impl.jar了,換句話說,容器已經提供了這個artifact對應的jar,所以,我們在運行階段,這個C1類直接可以用容器提供的portal-impl.jar中的B1類,而不會出任何問題。

 

實際插件的行爲:

剛纔我們講述的是理論部分,現在我們看下,實際插件在運行時候,是如何來區別對待scope=compile和scope=provided的情況的。

做一個實驗就可以很容易發現,當我們用maven install生成最終的構件包ProjectABC.war後,在其下的WEB-INF/lib中,會包含我們被標註爲scope=compile的構件的jar包,而不會包含我們被標註爲scope=provided的構件的jar包。這也避免了此類構件當部署到目標容器後產生包依賴衝突。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章