一、创建 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 文件即可,它们是名字发生了改变,本质上是同一个文件。