詳解IDEA多module項(xiàng)目maven依賴的一些說(shuō)明
不管eclipse有沒有被被時(shí)代拋棄,反正是被我拋棄了,因?yàn)镮DEA是真的好用
現(xiàn)在公司的項(xiàng)目基本都是基于maven的多module項(xiàng)目,controller,service,model,dao等都被分成了不同的module,這樣做當(dāng)然也是為了解耦。
這些module可根據(jù)需要在pom.xml配置來(lái)打成war包或者jar包
<packaging>jar</packaging>
web主項(xiàng)目設(shè)置packaging級(jí)別為war,dao、model這些module設(shè)置packaging級(jí)別為jar。
module之間可以通過module自己的pom.xml來(lái)進(jìn)行相互引用或依賴,如:
<dependency> <groupId>cn.com.autohome.mall</groupId> <artifactId>mall-common</artifactId> </dependency> <dependency> <groupId>cn.com.autohome.mall</groupId> <artifactId>mall-api-model</artifactId> </dependency>
這樣在 File -> project structure 下,選中主web項(xiàng)目
從上面的截圖可以看出來(lái)依賴的第三方j(luò)ar和依賴項(xiàng)目子module的區(qū)別。
maven在執(zhí)行install,packaging是jar的會(huì)被打成jar放在target目錄下,packaging是war的會(huì)被打成war放在target目錄下。
另外兩個(gè)target目錄會(huì)有一點(diǎn)區(qū)別,war的target目錄會(huì)多出來(lái)一個(gè)和module同名的文件夾,這個(gè)文件夾和war解壓后完全一致。
所有依賴的jar(包括依賴的module,被打成jar)都會(huì)被放lib下
這樣在部署的時(shí)候,只需要部署相應(yīng)的war即可。
關(guān)于Maven pom.xml中的元素modules、parent、properties以及import
多個(gè)module不需要分別執(zhí)行mvn命令,可以使用聚合(aggregator)來(lái)一次構(gòu)建全部模塊
modules
在父pom.xml中通過
<modules> <!-- 模塊都寫在此處 --> <module>mall-common</module> <module>mall-api-model</module> </modules>
來(lái)引用所有需要構(gòu)建的子模塊
parent
繼承,和java中的繼承相當(dāng),作用就是復(fù)用
場(chǎng)景
若每個(gè)子模塊都都用的了spring,那么我們是不是每個(gè)子模塊都需要單獨(dú)配置spring依賴了?這么做是可以的,但是我們有更優(yōu)的做法,那就是繼承,用parent來(lái)實(shí)現(xiàn)。
實(shí)現(xiàn)
父(account-aggregator)pom.xml
<modules> <!-- 模塊都寫在此處 --> <module>mall-common</module> <module>mall-api-model</module> </modules> <dependencies> <!-- 配置共有依賴 --> <!-- spring 依賴 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>4.0.2.RELEASE</version> </dependency> ······ <!-- junit 依賴 --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.7</version> <scope>test</scope> </dependency> </dependencies>
子pom.xml
<parent> <groupId>xx.xx.xx</groupId> <artifactId>aggregator</artifactId> <version>1.0.0-SNAPSHOT</version> <relativePath>../pom.xml</relativePath> <!-- 與不配置一樣,默認(rèn)就是尋找上級(jí)目錄下得pom.xml --> </parent> <dependencies> <!-- 配置自己獨(dú)有依賴 --> <dependency> <groupId>javax.mail</groupId> <artifactId>mail</artifactId> <version>1.4.3</version> </dependency> <dependency> <groupId>com.icegreen</groupId> <artifactId>greenmail</artifactId> <version>1.4.1</version> <scope>test</scope> </dependency> </dependencies>
依賴管理
繼承可以消除重復(fù),那是不是就沒有問題了? 答案是存在問題,假設(shè)將來(lái)需要添加一個(gè)新的子模塊util,只是提供一些簡(jiǎn)單的幫助工具,不需要依賴spring、junit,那么繼承后就依賴上了,有沒有什么辦法了?
有,maven已經(jīng)替我們想到了,那就是dependencyManagement元素,既能讓子模塊繼承到父模塊的依賴配置,又能保證子模塊依賴使用的靈活性。在dependencyManagement元素下得依賴聲明不會(huì)引入實(shí)際的依賴,不過它能夠約束dependencies下的依賴使用。
在父pom.xml中配置dependencyManagement元素
<modules> <!-- 模塊都寫在此處 --> <module>mall-common</module> <module>mall-api-model</module> </modules> <dependencyManagement> <dependencies> <!-- 配置共有依賴 --> <!-- spring 依賴 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>4.0.2.RELEASE</version> </dependency> ······ </dependencies> </dependencyManagement>
子pom.xml
<dependencies> <!-- spring 依賴 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-beans</artifactId> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> </dependency> <!-- junit 依賴 --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>4.0.2.RELEASE</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.0.16</version> </dependency> </dependencies>
使用這種依賴管理機(jī)制似乎不能減少太多的POM配置,就少了version(junit還少了個(gè)scope),感覺沒啥作用呀;其實(shí)作用還是挺大的,父POM使用dependencyManagement能夠統(tǒng)一項(xiàng)目范圍中依賴的版本,當(dāng)依賴版本在父POM中聲明后,子模塊在使用依賴的時(shí)候就無(wú)須聲明版本,也就不會(huì)發(fā)生多個(gè)子模塊使用版本不一致的情況,幫助降低依賴沖突的幾率。如果子模塊不聲明依賴的使用,即使該依賴在父POM中的dependencyManagement中聲明了,也不會(huì)產(chǎn)生任何效果。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
springboot 實(shí)現(xiàn)mqtt物聯(lián)網(wǎng)的示例代碼
這篇文章主要介紹了springboot 實(shí)現(xiàn)mqtt物聯(lián)網(wǎng),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03IDEA配置Tomcat后,控制臺(tái)tomcat?catalina?log出現(xiàn)亂碼問題
本文介紹了如何通過設(shè)置Tomcat和IDEA的編碼格式來(lái)解決編碼問題,首先嘗試修改Tomcat的logging.properties文件中的編碼設(shè)置,如果未解決問題,則調(diào)整IDEA的編碼設(shè)置,通過修改vmoptions文件來(lái)全局設(shè)置IDEA的編碼格式,作者分享了個(gè)人成功解決問題的方法和步驟,供其他開發(fā)者參考2024-09-09Java命令行運(yùn)行錯(cuò)誤之找不到或無(wú)法加載主類問題的解決方法
這篇文章主要給大家介紹了關(guān)于Java命令行運(yùn)行錯(cuò)誤之找不到或無(wú)法加載主類問題的解決方法,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-01-01詳解SpringCloudGateway內(nèi)存泄漏問題
這篇文章主要介紹了詳解SpringCloudGateway內(nèi)存泄漏問題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07詳解Java分布式系統(tǒng)中session一致性問題
這篇文章主要介紹了Java分布式系統(tǒng)中session一致性問題,對(duì)分布式系統(tǒng)感興趣的同學(xué),要仔細(xì)看一下2021-04-04Spring boot + mybatis + Vue.js 
這篇文章主要介紹了Spring boot + mybatis + Vue.js + ElementUI 實(shí)現(xiàn)數(shù)據(jù)的增刪改查實(shí)例代碼(二),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-05-05