一、创建 Maven 工程 1、使用命令生成Maven工程
在工作目录打开命令行
运行 mvn archetype:generate 命令
下面根据提示操作
TIP
Choose a number or apply filter (format: [groupId:]artifactId, case sensitive contains): 7:【直接回车,使用默认值】
Define value for property ‘groupId’: com.atguigu.maven
Define value for property ‘artifactId’: pro01-maven-java
Define value for property ‘version’ 1.0-SNAPSHOT: :【直接回车,使用默认值】
Define value for property ‘package’ com.atguigu.maven: :【直接回车,使用默认值】
Confirm properties configuration: groupId: com.atguigu.maven artifactId: pro01-maven-java version: 1.0-SNAPSHOT package: com.atguigu.maven Y: :【直接回车,表示确认。如果前面有输入错误,想要重新输入,则输入 N 再回车。】
2、调整 Maven 默认生成的工程,对 junit 依赖的是较低的 3.8.1 版本,我们可以改成较适合的 4.12 版本。
自动生成的 App.java 和 AppTest.java 可以删除。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
<!-- 依赖信息配置 -->
<!-- dependencies复数标签:里面包含dependency单数标签 -->
<dependencies>
<!-- dependency单数标签:配置一个具体的依赖 -->
<dependency>
<!-- 通过坐标来依赖其他jar包 -->
<groupId> junit</groupId>
<artifactId> junit</artifactId>
<version> 4.12</version>
<!-- 依赖的范围 -->
<scope> test</scope>
</dependency>
</dependencies>
3、自动生成的 pom.xml 解读 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<!-- modelVersion 标签:从maven2 开始就是固定为 4.0.0,代表当前pom.xml所采用的标签结构 -->
<modelVersion> 4.0.0</modelVersion>
<!-- 当前Maven工程的坐标 -->
<groupId> com.atguigu.maven</groupId>
<artifactId> pro01-maven-java</artifactId>
<version> 1.0-SNAPSHOT</version>
<!-- 当前Maven工程的打包方式,可选值有下面三种: -->
<!-- jar:表示这个工程是一个Java工程 -->
<!-- war:表示这个工程是一个Web工程 -->
<!-- pom:表示这个工程是“管理其他工程”的工程 -->
<packaging> jar</packaging>
<name> pro01-maven-java</name>
<url> http://maven.apache.org</url>
<properties>
<!-- 工程构建过程中读取源码时使用的字符集 -->
<project.build.sourceEncoding> UTF-8</project.build.sourceEncoding>
</properties>
<!-- 当前工程所依赖的jar包 -->
<dependencies>
<!-- 使用dependency配置一个具体的依赖 -->
<dependency>
<!-- 在dependency标签内使用具体的坐标依赖我们需要的一个jar包 -->
<groupId> junit</groupId>
<artifactId> junit</artifactId>
<version> 4.12</version>
<!-- scope标签配置依赖的范围 -->
<scope> test</scope>
</dependency>
</dependencies>
二、编写代码 1、主体程序
主体程序指的是被测试的程序,同时也是将来在项目中真正要使用的程序。
1
2
3
4
5
6
7
8
9
package com.atguigu.maven ;
public class Calculator {
public int sum ( int i , int j ){
return i + j ;
}
}
2、测试程序
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
package com.atguigu.maven ;
import org.junit.Test ;
import com.atguigu.maven.Calculator ;
// 静态导入的效果是将Assert类中的静态资源导入当前类
// 这样一来,在当前类中就可以直接使用Assert类中的静态资源,不需要写类名
import static org.junit.Assert.* ;
public class CalculatorTest {
@Test
public void testSum (){
// 1.创建Calculator对象
Calculator calculator = new Calculator ();
// 2.调用Calculator对象的方法,获取到程序运行实际的结果
int actualResult = calculator . sum ( 5 , 3 );
// 3.声明一个变量,表示程序运行期待的结果
int expectedResult = 8 ;
// 4.使用断言来判断实际结果和期待结果是否一致
// 如果一致:测试通过,不会抛出异常
// 如果不一致:抛出异常,测试失败
assertEquals ( expectedResult , actualResult );
}
}
三、执行maven构建 1、要求 运行 Maven 中和构建操作相关的命令时,必须进入到 pom.xml 所在的目录。如果没有在 pom.xml 所在的目录运行 Maven 的构建命令,那么会看到下面的错误信息:
The goal you specified requires a project to execute but there is no POM in this directory
TIP
mvn -v 命令和构建操作无关,只要正确配置了 PATH,在任何目录下执行都可以。而构建相关的命令要在 pom.xml 所在目录下运行——操作哪个工程,就进入这个工程的 pom.xml 目录。
2、清理操作 mvn clean
效果:删除 target 目录
3、编译操作 主程序编译:mvn compile
测试程序编译:mvn test-compile
主体程序编译结果存放的目录:target/classes
测试程序编译结果存放的目录:target/test-classes
4、测试操作 mvn test
测试的报告存放的目录:target/surefire-reports
5、打包操作 mvn package
打包的结果——jar 包,存放的目录:target
并没有把依赖的包(maven dependency)一起打在生成的jar包里,这里的打jar包,实际maven认为是一个工具包,是一个后面被项目继续依赖的包,所以没必要把依赖的包打进去。
如果需要生成一个可执行的包,则需要用maven插件: 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<plugin>
<groupId> org.apache.maven.plugins</groupId>
<artifactId> maven-jar-plugin</artifactId>
<version> 2.4</version>
<configuration>
<archive>
<manifest>
<useUniqueVersions> false</useUniqueVersions>
<addClasspath> true</addClasspath>
<classpathPrefix> lib/</classpathPrefix>
<mainClass> com.wyz.Main</mainClass>
</manifest>
</archive>
</configuration>
</plugin>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<plugin>
<groupId> org.apache.maven.plugins</groupId>
<artifactId> maven-dependency-plugin</artifactId>
<executions>
<execution>
<id> copy-dependencies</id>
<phase> package</phase>
<goals>
<goal> copy-dependencies</goal>
</goals>
<configuration>
<!-- 拷贝项目依赖包到lib/目录下 -->
<outputDirectory> ${project.build.directory}/lib</outputDirectory>
<!-- 间接依赖也拷贝 -->
<excludeTransitive> false</excludeTransitive>
<!-- 带上版本号 -->
<stripVersion> false</stripVersion>
</configuration>
</execution>
</executions>
</plugin>
把依赖也打进jar包:mainClass是jar包的main方法入口: 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<build>
<plugins>
<plugin>
<artifactId> maven-assembly-plugin</artifactId>
<configuration>
<archive>
<manifest>
<mainClass> com.wyz.Main</mainClass>
</manifest>
</archive>
<descriptorRefs>
<descriptorRef> jar-with-dependencies</descriptorRef>
</descriptorRefs>
</configuration>
</plugin>
</plugins>
</build>
6、安装操作 mvn install
1
2
[INFO] Installing D:\maven-workspace\space201026\pro01-maven-java\target\pro01-maven-java-1.0-SNAPSHOT.jar to D:\maven-rep1026\com\atguigu\maven\pro01-maven-java\1.0-SNAPSHOT\pro01-maven-java-1.0-SNAPSHOT.jar
[INFO] Installing D:\maven-workspace\space201026\pro01-maven-java\pom.xml to D:\maven-rep1026\com\atguigu\maven\pro01-maven-java\1.0-SNAPSHOT\pro01-maven-java-1.0-SNAPSHOT.pom
安装的效果是将本地构建过程中生成的 jar 包存入 Maven 本地仓库。这个 jar 包在 Maven 仓库中的路径是根据它的坐标生成的。
坐标信息如下:
1
2
3
<groupId>com.atguigu.maven</groupId>
<artifactId>pro01-maven-java</artifactId>
<version>1.0-SNAPSHOT</version>
在 Maven 仓库中生成的路径如下:
maven\repository\com\atguigu\maven\pro01-maven-java\1.0-SNAPSHOT\pro01-maven-java-1.0-SNAPSHOT.jar
另外,安装操作还会将 pom.xml 文件转换为 XXX.pom 文件一起存入本地仓库。所以我们在 Maven 的本地仓库中想看一个 jar 包原始的 pom.xml 文件时,查看对应 XXX.pom 文件即可,它们是名字发生了改变,本质上是同一个文件。