2018-12-17 從零開始用好 Maven : 從 Hello World 到日常使用

轉(zhuǎn)載自:https://mp.weixin.qq.com/s/HMBq5_NgBiiqJx7F_VtTzA

(主要是下面有一些最佳實踐陆馁,很實用找颓,有時間,總結(jié)到github里叮贩。)

來源:lmportNew - 唐尤華

1. Maven簡介

Apache Maven 是一個軟件項目管理工具击狮》鹞觯基于項目對象模型(POM)的理念,通過一段核心描述信息來管理項目構(gòu)建彪蓬、報告和文檔信息说莫。

Maven 是一個意第緒語(猶太人使用的國際語)單詞,意思是知識的累加器寞焙。它最開始是被用來簡化 Jakarta Turbine 項目的構(gòu)建過程储狭。在 Jakarta Turbine 項目中有幾個不同的項目,雖然它們的Ant構(gòu)建文件差異很小捣郊,但是 jar 包都在 CVS 上辽狈。于是想要找到一個標準而又簡單的項目構(gòu)建方法,既可以清晰地定義出這個項目由什么構(gòu)成并發(fā)布項目信息呛牲,又能在不同項目間共享Jar包刮萌。

現(xiàn)在,任何一個基于Java的項目都能使用Maven來構(gòu)建和管理娘扩,使 Java 開發(fā)人員的日常工作變得更輕松着茸,讓Java項目更容易被理解。

2. Maven使用

2.1 安裝

必備條件: 已安裝JDK
注意事項: Maven 3.3 及更高版本要求 JDK1.7 或者更高版本

2.2 Windows

下載解壓縮

bin\
boot\
conf\
lib\
README.txt
NOTICE
LICENSE

配置環(huán)境變量

  • 計算機 > 屬性 > 高級系統(tǒng)設(shè)置 > 環(huán)境變量 > 系統(tǒng)變量
  • 新建 M2_HOME 變量灰殴,內(nèi)容為 {解壓路徑}\apache-maven-{版本號}
  • 編輯 Path 變量敬特,在內(nèi)容結(jié)尾加上 ;%M2_HOME%\bin;

2.3 Linux

包管理器安裝

$ sudo apt install maven

下載安裝

  • 下載 apache-maven-{版本號}-bin.tar.gz
  • 配置環(huán)境變量 export PATH=/opt/apache-maven-{版本號}/bin:$PATH

2.4 驗證

Windows 打開 Cmd,Linux 運行 Shell牺陶,看到下面信息表示安裝成功伟阔。

$ mvn -version
Apache Maven 3.3.9 (bb52d8502b132ec0a5a3f4c09453c07478323dc5; 2015-11-11T00:41:47+08:00)
Maven home: D:\software\java\apache-maven-3.3.9
Java version: 1.8.0_191, vendor: Oracle Corporation
Java home: c:\Program Files\java\jdk1.8.0_191\jre
Default locale: zh_CN, platform encoding: GBK
OS name: "windows 7", version: "6.1", arch: "amd64", family: "dos"

2.5 設(shè)置Maven

Maven通過 settings.xml 進行配置
完整的參數(shù)說明可查看

http://maven.apache.org/ref/3.6.0/maven-settings/settings.html

2.5.1 自定義倉庫位置(可選)
Maven 下載的 jar 包默認存儲到 ${user.home}/.m2/repository
編輯 {安裝路徑}\config\settings.xml,在下面增加一行填入自定義位置:

  <!-- localRepository
   | The path to the local repository maven will use to store artifacts.
   |
   | Default: ${user.home}/.m2/repository
  <localRepository>/path/to/local/repo</localRepository>
  -->
<localRepository>{自定義位置}\repository</localRepository>

Linux 查看安裝路徑

$ ls -lsa /usr/share/maven
...
 0 lrwxrwxrwx   1 root root    10 12月 10  2015 conf -> /etc/maven

$ ls -lsa /etc/maven
 4 drwxr-xr-x   2 root root  4096 11月 27 11:45 logging
 4 -rw-r--r--   1 root root   222 11月 19  2015 m2.conf
12 -rw-r--r--   1 root root 10216 11月 19  2015 settings.xml
 4 -rw-r--r--   1 root root  3649 11月 19  2015 toolchains.xml

2.5.2 設(shè)置國內(nèi)鏡像(可選)
Maven 默認從中央倉庫 central 下載
改為國內(nèi)鏡像速度更快
編輯 {安裝路徑}\config\settings.xml掰伸,在 <mirrors></mirrors> 標簽里加入新的鏡像:

<mirrors>
    <mirror>
      <id>alimaven</id>
      <mirrorOf>central</mirrorOf>
      <name>aliyun maven</name>
      <url>https://maven.aliyun.com/repository/central</url>
    </mirror>
</mirrors>

3. 使用

3.1 快速上手
3.1.1 新建示例項目
命令行不是必須的皱炉,但這個過程能有助于理解在 IDE 中的操作。
命令行新建項目
Windows 打開 Cmd狮鸭,Linux 運行 Shell合搅,執(zhí)行下面指令。

mvn archetype:generate -DgroupId=org.tyh.mvn.quickstart -DartifactId=mvn-quickstart -DarchetypeArtifactId=maven-archetype-quickstart -DarchetypeVersion=1.3 -DinteractiveMode=false

執(zhí)行成功可以看到下面字樣:

[INFO] BUILD SUCCESS

POM.xml 包含了命令中的信息

<groupId>org.tyh.mvn.quickstart</groupId>
<artifactId>mvn-quickstart</artifactId>
<version>1.0-SNAPSHOT</version>
<name>mvn-quickstart</name>

目錄結(jié)構(gòu)
quickstart 項目的結(jié)構(gòu)如下:

  • 項目源碼:src/main/java
  • Web 項目源碼:src/main/webapp
  • 測試源碼:src/test/java
  • Maven 項目結(jié)構(gòu)(Project Object Model POM):pom.xml

注意: 配置文件怕篷,如 log4j.properties 需要新建 src\main\resources 目錄历筝。這樣編譯時會打包到生成的 jar 中。

mvn-quickstart
│  pom.xml
│  
└─src
    ├─main
    │  └─java
    │      └─org
    │          └─tyh
    │              └─mvn
    │                  └─quickstart
    │                          App.java
    │                          
    └─test
        └─java
            └─org
                └─tyh
                    └─mvn
                        └─quickstart
                                AppTest.java

提示: 生成目錄結(jié)構(gòu)廊谓,Windows 在 Cmd 中輸入 tree /f,Linux 安裝 tree 程序后可直接輸入 tree麻削。
有關(guān)目錄結(jié)構(gòu)完整介紹可以查看

http://maven.apache.org/guides/introduction/introduction-to-the-standard-directory-layout.html

3.1.2 構(gòu)建項目
Windows 打開 Cmd蒸痹,Linux 運行 Shell春弥,執(zhí)行下面指令。

mvn package

執(zhí)行成功可以看到下面字樣:

[INFO] BUILD SUCCESS

查看生成結(jié)果叠荠,在項目中新增了 target 目錄匿沛,里面主要關(guān)注以下文件:

  • class 文件:target\classes\org\tyh\mvn\quickstart\App.class
  • test-classes 文件:target\test-classes\org\tyh\mvn\quickstart\AppTest.class
  • jar 文件:target\mvn-quickstart-1.0-SNAPSHOT.jar
mvn-quickstart
│  pom.xml
│ 
└─target
    │  mvn-quickstart-1.0-SNAPSHOT.jar
    │  
    ├─classes
    │  └─org
    │      └─tyh
    │          └─mvn
    │              └─quickstart
    │                      App.class
    │                      
    ├─generated-sources
    │  └─annotations
    ├─generated-test-sources
    │  └─test-annotations
    ├─maven-archiver
    │      pom.properties
    │      
    ├─maven-status
    │  └─maven-compiler-plugin
    │      ├─compile
    │      │  └─default-compile
    │      │          createdFiles.lst
    │      │          inputFiles.lst
    │      │          
    │      └─testCompile
    │          └─default-testCompile
    │                  createdFiles.lst
    │                  inputFiles.lst
    │                  
    ├─surefire-reports
    │      org.tyh.mvn.quickstart.AppTest.txt
    │      TEST-org.tyh.mvn.quickstart.AppTest.xml
    │      
    └─test-classes
        └─org
            └─tyh
                └─mvn
                    └─quickstart
                            AppTest.class

3.1.3 運行
Windows 打開 Cmd,Linux 運行 Shell榛鼎,執(zhí)行下面指令逃呼。

java -cp target/mvn-quickstart-1.0-SNAPSHOT.jar org.tyh.mvn.quickstart.App
Hello World!

執(zhí)行測試:

mvn test

執(zhí)行成功可以看到下面的結(jié)果:

[INFO] -------------------------------------------------------
[INFO]  T E S T S
[INFO] -------------------------------------------------------
[INFO] Running org.tyh.mvn.quickstart.AppTest
[INFO] Tests run: 1, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 0.133 s - in org.tyh.mvn.quickstart.AppTest
[INFO]
[INFO] Results:
[INFO]
[INFO] Tests run: 1, Failures: 0, Errors: 0, Skipped: 0

3.2 新增依賴
3.2.1 搜索Maven
為項目添加一個依賴,比如 Apache Commons Lang 和 Slf4j 日志者娱。
搜索
搜索時可采用高級搜索抡笼,g:{groupId} a:{artifactId}。例如 g:log4j a:log4j 就會列出 log4j 的最新版本黄鳍。

注意: 類似 slf4j 這樣依賴其他實現(xiàn)的包推姻,需要查看官方文檔,確認需要配合使用的 jar 包框沟。否則會出 現(xiàn)編譯通過藏古,運行報錯 的情況。

3.2.2 加入依賴項

<dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>

    <!--Slf4j(slf4j-log4j12)-->
    <!--添加后忍燥,會同時引入 log4j 和 slf4j-api-->
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-log4j12</artifactId>
      <version>1.8.0-beta2</version>
    </dependency>
 
    <!--Apache Commons Lang (commons-lang3)-->
    <dependency>
      <groupId>org.apache.commons</groupId>
      <artifactId>commons-lang3</artifactId>
      <version>3.8.1</version>
    </dependency>
</dependencies>

3.2.3 驗證
修改 App 類拧晕,加入 Log 和 測試代碼:

package org.tyh.mvn.quickstart;

import org.apache.commons.lang3.ArrayUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
 * ArrayUtils Demo
 *
 */
public class App 
{
    public static void main( String[] args )
    {
        Logger logger = LoggerFactory.getLogger(App.class);
 
        float[] farr = {1.1f, 1.2f, 1.3f};
        logger.info(ArrayUtils.toString(farr));
 
        farr = ArrayUtils.removeElements(farr, 1.1f);
        logger.info(ArrayUtils.toString(farr));
    }
}

執(zhí)行程序之前,要找到依賴的 jar 文件所在的目錄梅垄。默認是在 {用戶主目錄}/.m2/ 目錄 下防症,利用 dependency:copy 插件 可以拷貝到 target\dependency 目錄:

mvn dependency:copy-dependencies

查看結(jié)果:

├─dependency
│      commons-lang3-3.8.1.jar
│      hamcrest-core-1.3.jar
│      junit-4.11.jar
│      log4j-1.2.17.jar
│      slf4j-api-1.8.0-beta2.jar
│      slf4j-log4j12-1.8.0-beta2.jar

在命令行運行時,用 -cp 加入依賴的 jar 所在目錄:

java -cp .;dependency/*;mvn-quickstart-1.0-SNAPSHOT.jar org.tyh.mvn.quickstart.App

注意: 編譯前需要加入 log4j.properties 到 src\main\resources 目錄哎甲。下面是一個 Windows 下的 log4j.properties蔫敲。

# Root logger option
log4j.rootLogger=INFO, file, stdout
 
# Direct log messages to a log file
log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=C:\\temp\\logging.log
log4j.appender.file.MaxFileSize=10MB
log4j.appender.file.MaxBackupIndex=10
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
 
# Direct log messages to stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

3.3 IDE中使用
3.3.1 Eclipse
新建項目

  1. 新建 Maven 項目
  • File > New > Project
  • 選擇 Maven Project (目錄報錯及解決辦法*)
  • (可選)項目類型 maven-archetype-simple 或其他類型
  • 輸入 Group Id, Artifact Id, Name,F(xiàn)inish
  1. 添加依賴
  • pom.xml 右鍵菜單 > Maven > Add Dependency
  • 在輸入框中輸入炭玫,比如 slf4j 會自動列出匹配結(jié)果奈嘿,OK
  • 加入新的依賴保存文件,會在 Maven Dependencies 中列出 jar 及路徑吞加,并添加到項目的 classpath 中
  1. 編碼
  • 編寫 Java 代碼裙犹,調(diào)試
  1. 構(gòu)建
  • 項目 右鍵菜單 > Run As > Maven build
  • 第一次運行會提示輸入 Maven build 的目標:Goal 里填寫 package 進行構(gòu)建 (支持的常用命令可以在這里找到 Maven in 5 Minutes:Maven Phases)

導入項目

  • File > Import
  • 選擇 Maven > Existing Maven Project
  • 選擇項目 pom.xml 目錄,Projects: 下面勾選 target
  • 點擊完成

3.3.2 Idea

  1. 新建 Maven 項目
  • File > New > Project
  • 選擇 Maven
  • (可選)項目類型 maven-archetype-simple 或其他類型
  • 輸入 Group Id, Artifact Id
  • 輸入項目名稱衔憨,F(xiàn)inish
  1. 添加依賴
  • pom.xml 手動添加依賴信息
  • 加入新的依賴保存文件叶圃,會在 External Libraries 中列出 jar 及路徑,并添加到項目的 classpath 中
  1. 編碼
  • 編寫 Java 代碼践图,調(diào)試
  1. 構(gòu)建
  • pom.xml 右鍵菜單 > Build module’module name’
  • Maven build 會提示警告:Warning:java: 源值1.5已過時, 將在未來所有發(fā)行版中刪除:可加入配置項解決

4. 常見問題與辦法

4.1 如何設(shè)置編譯支持的 JDK 版本掺冠?
全局指定
下面的腳本指定編譯版本兼容 JDK 1.7

<project>
  ...
  <properties>
    <maven.compiler.source>1.7</maven.compiler.source>
    <maven.compiler.target>1.7</maven.compiler.target>
  </properties>
  ...
</project>

指定插件
在不改變?nèi)旨嫒菪缘那闆r下,可以在插件中指定码党。例如德崭,下面的腳本指定了 maven-compiler-plugin 編譯的版本兼容 JDK 1.7斥黑。

<project>
  ...
  <build>
  ...
    <plugins>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>3.3</version>
        <configuration>
          <source>1.7</source>
          <target>1.7</target>
        </configuration>
      </plugin>
    </plugins>
  ...
  </build>
  ...
</project>

4.2 如何指定自己的目錄結(jié)構(gòu)?
可以通過設(shè)置 <build> 節(jié)點下 <sourceDirectory>, <resources> 參數(shù)指定眉厨。
4.3 在 pom 文件中配置了依賴锌奴,編譯時還會報錯。
下載的 jar 文件可能有問題憾股。

  • 檢查 maven 倉庫地址鹿蜀,在搜索條件中檢查 groupId 和 artifactId 是否正確。
  • mvn clean 清理文件服球。
  • mvn package 重新編譯茴恰。
    4.4 [WARNING] File encoding has not been set, using platform encoding UTF-8, i.e. build is platform dependent!
    POM 文件中沒有指定編譯時編碼格式,可加入下面屬性指定為 UTF-8有咨。
<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>

類似的問題: [WARNING] Using platform encoding (Cp1252 actually) to copy filtered resources, i.e. build is platform dependent!

4.5 Invalid project description. … overlaps the workspace …
Eclipse 新建 Maven 項目時琐簇,可能會報告此錯誤。解決辦法兩種:

  • 選擇 workspace 以外的目錄作為項目目錄座享;
  • 新建 Java Project婉商,然后轉(zhuǎn)為 Maven 項目:右鍵菜單 Config -> Convert to Maven Project

4.6 Warning:java: 源值1.5已過時, 將在未來所有發(fā)行版中刪除
Idea 在 Maven Build 時發(fā)出警告,在 pom.xml 中加入以下內(nèi)容:

<build>
    <sourceDirectory>src</sourceDirectory>
    <plugins>
        <plugin>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.8.0</version>
            <configuration>
                <source>1.8</source>
                <target>1.8</target>
            </configuration>
        </plugin>
    </plugins>
</build>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末渣叛,一起剝皮案震驚了整個濱河市丈秩,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌淳衙,老刑警劉巖蘑秽,帶你破解...
    沈念sama閱讀 221,548評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異箫攀,居然都是意外死亡肠牲,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,497評論 3 399
  • 文/潘曉璐 我一進店門靴跛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來缀雳,“玉大人,你說我怎么就攤上這事梢睛》视。” “怎么了?”我有些...
    開封第一講書人閱讀 167,990評論 0 360
  • 文/不壞的土叔 我叫張陵绝葡,是天一觀的道長深碱。 經(jīng)常有香客問我,道長藏畅,這世上最難降的妖魔是什么敷硅? 我笑而不...
    開封第一講書人閱讀 59,618評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上竞膳,老公的妹妹穿的比我還像新娘航瞭。我一直安慰自己诫硕,他們只是感情好坦辟,可當我...
    茶點故事閱讀 68,618評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著章办,像睡著了一般锉走。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上藕届,一...
    開封第一講書人閱讀 52,246評論 1 308
  • 那天挪蹭,我揣著相機與錄音,去河邊找鬼休偶。 笑死梁厉,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的踏兜。 我是一名探鬼主播词顾,決...
    沈念sama閱讀 40,819評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼碱妆!你這毒婦竟也來了肉盹?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,725評論 0 276
  • 序言:老撾萬榮一對情侶失蹤疹尾,失蹤者是張志新(化名)和其女友劉穎上忍,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體纳本,經(jīng)...
    沈念sama閱讀 46,268評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡窍蓝,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,356評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了繁成。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吓笙。...
    茶點故事閱讀 40,488評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖朴艰,靈堂內(nèi)的尸體忽然破棺而出观蓄,到底是詐尸還是另有隱情,我是刑警寧澤祠墅,帶...
    沈念sama閱讀 36,181評論 5 350
  • 正文 年R本政府宣布侮穿,位于F島的核電站,受9級特大地震影響毁嗦,放射性物質(zhì)發(fā)生泄漏亲茅。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,862評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望克锣。 院中可真熱鬧茵肃,春花似錦、人聲如沸袭祟。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,331評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽巾乳。三九已至您没,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間胆绊,已是汗流浹背氨鹏。 一陣腳步聲響...
    開封第一講書人閱讀 33,445評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留压状,地道東北人仆抵。 一個月前我還...
    沈念sama閱讀 48,897評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像种冬,于是被迫代替她去往敵國和親镣丑。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,500評論 2 359

推薦閱讀更多精彩內(nèi)容