Java的項目構(gòu)建工具M(jìn)aven的配置和使用教程
一、Maven是什么
Maven是一個用java開發(fā)的項目構(gòu)建工具, 它能使項目構(gòu)建過程中的編譯、測試、發(fā)布、文檔自動化, 大大減輕了程序員部署負(fù)擔(dān)。
二、安裝Maven
安裝maven非常簡單,訪問Maven官方頁下載即可:http://maven.apache.org/download.cgi
下載完后配置M2_HOME環(huán)境變量, 然后終端運(yùn)行mvn --version, 看到正確的輸出提示,Maven就安裝完成了。
三、Maven基本概念
Maven的核心思想是POM, 即Project Object Model(項目對象模型)。POM文件是以XML文件的形式描述一個Maven項目所用到的資源(源碼、依賴、測試等)。下圖描述了POM文件的結(jié)構(gòu), 以及Maven是如何調(diào)用POM文件的。

當(dāng)執(zhí)行一條Maven命令時, 會傳入一個pom文件, Maven會在該pom里面的描述的資源上執(zhí)行
POM文件:
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<!-- The Basics -->
<groupId>...</groupId>
<artifactId>...</artifactId>
<version>...</version>
<packaging>...</packaging>
<dependencies>...</dependencies>
<parent>...</parent>
<dependencyManagement>...</dependencyManagement>
<modules>...</modules>
<properties>...</properties>
<!-- Build Settings -->
<build>...</build>
<reporting>...</reporting>
<!-- More Project Information -->
<name>...</name>
<description>...</description>
<url>...</url>
<inceptionYear>...</inceptionYear>
<licenses>...</licenses>
<organization>...</organization>
<developers>...</developers>
<contributors>...</contributors>
<!-- Environment Settings -->
<issueManagement>...</issueManagement>
<ciManagement>...</ciManagement>
<mailingLists>...</mailingLists>
<scm>...</scm>
<prerequisites>...</prerequisites>
<repositories>...</repositories>
<pluginRepositories>...</pluginRepositories>
<distributionManagement>...</distributionManagement>
<profiles>...</profiles>
</project>
modelVersion是POM模型版本, 4.0.0支持Maven2和3
Maven Coordinates(Maven坐標(biāo))
(1)groupId: 它是一個組織或者項目的唯一ID, 大多數(shù)情況下會使用項目的java包的根名作為groupID, 例如com.pastqing
(2)artifactId:它是正在構(gòu)建的項目名稱, 例如一個支付系統(tǒng)artifactId是web-pay。artifactId 是Maven倉庫中g(shù)roupId目錄下的子目錄名
(3)version:顧名思義項目發(fā)行的版本號
以上三項都是構(gòu)建結(jié)果名稱的一部分, 在項目構(gòu)建后會生成一個jar包,位于Maven倉庫的路徑就是MAVEN_REPO/com/pastqing/web-pay/1.0/web-pay-1.0.jar
四、一個用Maven構(gòu)建的Hello World java項目
利用Maven插件archetype構(gòu)建一個項目:
在終端中打開工作目錄
運(yùn)行命令:
mvn archetype:generate
, 第一次運(yùn)行時比較慢,原因是第一次需要從Maven中央倉庫中下載相關(guān)項目原型。下載完畢后,會選擇項目模型,以及輸入groupId, artifactId,version等,構(gòu)建完畢后會有成功提示。
打包項目:切換到項目根目錄,運(yùn)行mvn package。打包成功之后,項目會生成一個target文件夾,里面有生成好的jar文件和class文件。
運(yùn)行jar文件:
java -cp target/helloWorld-1.0-SNAPSHOT.jar com.pastqing.App
至此一個最簡單Maven構(gòu)建的java項目就完成了。
五、一個用Maven構(gòu)建的java-web項目
生成一個web項目與生成java項目基本類似,只是用的模型不同而已。這里不再闡述。下面我們具體說說如何使用Tomcat或者jetty插件運(yùn)行web項目。這里我們以tomcat舉例。
Maven Tomcat插件安裝: http://tomcat.apache.org/maven-plugin-2.2/
我們將如下插件信息加入到web項目中的POM文件中
<plugin> <groupId>org.apache.tomcat.maven</groupId> <artifactId>tomcat6-maven-plugin</artifactId> <version>2.2</version> </plugin> <plugin> <groupId>org.apache.tomcat.maven</groupId> <artifactId>tomcat7-maven-plugin</artifactId> <version>2.2</version> </plugin>
這樣我們集成了這個tomcat的Maven插件, 只需要一個命令就可以部署、啟動服務(wù)了。命令如下:
mvn tomcat:run
(tomcat6)
mvn tomcat7:run
(tomcat7)
使用tomcat Maven插件自動部署到外部tomcat
以上自動部署,會使用Maven內(nèi)嵌的Tomcat, 下面我們修改POM文件, 讓項目部署到外部的Tomcat中。
修改項目POM文件,添加服務(wù)器配置信息
<plugin> <groupId>org.apache.tomcat.maven</groupId> <artifactId>tomcat7-maven-plugin</artifactId> <version>2.2</version> <configuration> <url>http://localhost:8080/manager/text</url> <server>tomcat7</server> <username>admin</username> <password>admin</password> </configuration> </plugin>
其中server, username, password的值與%Maven_HOME中的setting.xml中的server, username, password一一對應(yīng)。
啟動外部tomcat, 運(yùn)行命令mvn tomcat7:redeploy
六、如何用Maven構(gòu)建多模塊項目
1.父POM
所有的Maven pom文件都繼承自一個父POM, 如果沒有指定父pom, 則該pom文件繼承自根POM。pom文件的集成關(guān)系如下圖所示:

可以讓一個pom文件顯式地繼承另一個pom文件。這樣,可以通過修改公共父pom文件的設(shè)置來修改所有子pom文件的設(shè)置。這里我們使用parent標(biāo)簽來定義父pom。下面我們具體搭建一個多模塊Mavne項目
2.構(gòu)建項目目錄結(jié)構(gòu)
我們創(chuàng)建一個maven-web項目, 名字叫EducationCloud, 接下來我們在項目目錄下創(chuàng)建幾個文件夾用來劃分我們的模塊。它們分別是Education-parent(父模塊), Education-core(業(yè)務(wù)), Education-entity(實體), Education-web(web服務(wù))

目錄的劃分可以根據(jù)需要進(jìn)行, 我的劃分如上
3.修改pom文件
我們用module標(biāo)簽來進(jìn)行劃分模塊。打開根目錄下的pom文件, 添加moudle標(biāo)簽。
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.EducationCloud</groupId>
<artifactId>EducationCloud</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>pom</packaging>
<modules>
<module>Education-parent</module>
<module>Education-core</module>
<module>Education-entity</module>
<module>Education-web</module>
</modules>
<name>EducationCloud</name>
</project>
這里我們說下packaging標(biāo)簽:最常見的就是打包為jar, war了。任何一個Maven項目都需要定義pom文件中的packaging元素, 如果不聲明該元素, 則默認(rèn)打包為jar, 如果定義值為war那么就打包為war包。如果值為pom,那么什么包都不生成(通常用于父模塊)。
給各個模塊添加parent標(biāo)簽:
parent標(biāo)簽用來定義父POM的坐標(biāo)位置的, 定義如下:
<parent> <groupId>com.EducationCloud</groupId> <artifactId>EducationCloud-parent</artifactId> <version>1.0-SNAPSHOT</version> <relativePath></relativePath> </parent>
groupId, aritfactId, version是常規(guī)表示父pom位置信息的元素, relativePath是表示父pom位置的相對路徑, 默認(rèn)為../pom.xml, 這里需要注意的是groupId, aritfactId, version必須與父pom文件中的對應(yīng)起來
使用dependencyManagement管理項目所有依賴
為了統(tǒng)一管理依賴,我們在父項目模塊的pom文件中使用dependencyManagement來聲明項目的所有依賴, 這樣在其他的子項目中引用依賴時就可以省略版本號的編寫, 修改起來也很容易。
編寫**父項目模塊**educationCloud-parent的pom文件, 添加如下:
使用pluginManagement管理項目中的Maven插件
為了統(tǒng)一管理項目中的Maven插件, 如Maven編譯插件, 打包插件等及其配置信息, 在父項目 pom文件中添加pluginManagement來管理, 這樣在所有子模塊中引用的插件都會統(tǒng)一處理, 添加如下:
<pluginManagement>
<plugins>
<!-- complile插件的配置 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-complier-plugin</artifactId>
<version>3.3</version>
<configuration>
<source>1.7</source>
<target>1.7</target>
<encoding>UTF-8</encoding>
</configuration>
<plugin>
</plugins>
</pluginManagement>
上面我們添加了maven編譯插件的配置,用jdk1.7編譯, 保存后我們可以在各個子模塊的Effective pom中看到相應(yīng)的修改。
使用properties標(biāo)簽定義常量:
我們將各個依賴的版本號定義為不同的常量,這樣方便以后的修改:
<properties> <jdkVersion>1.7</jdkVersion> <servletVersion>3.1.0</servletVersion> <mysqlVersion>5.1.34</mysqlVersion> <junitVersion>4.12</junitVersion> <defaultEncoding>UTF-8</defaultEncoding> </properties>
引用時用${jdkVersion}的形式引用即可。
注,以上操作均可在IDE中操作, 更加方便簡單。
相關(guān)文章
使用Spring啟動時運(yùn)行自定義業(yè)務(wù)
這篇文章主要介紹了使用Spring啟動時運(yùn)行自定義業(yè)務(wù)的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07
JDK 5 提供的注解:Target、Inherited和Documented的區(qū)別
這篇文章主要介紹了JDK 5 提供的注解:Target、Inherited和Documented的區(qū)別,需要的朋友可以參考下2016-02-02
SpringBoot上傳圖片到指定位置并返回URL的實現(xiàn)
本文主要介紹了SpringBoot上傳圖片到指定位置并返回URL,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下<BR>2022-03-03
Java日常練習(xí)題,每天進(jìn)步一點點(54)
下面小編就為大家?guī)硪黄狫ava基礎(chǔ)的幾道練習(xí)題(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,希望可以幫到你2021-08-08
SpringBoot項目為何引入大量的starter?如何自定義starter?
這篇文章主要介紹了SpringBoot項目為何引入大量的starter?如何自定義starter?文章基于這兩個問題展開全文,需要的小伙伴可以參考一下2022-04-04

