Maven项目的核心是pom.xml。POM(Project Object Model,项目对象模型)定义了项目的基本信息,用于描述项目如何构建,声明项目依赖等等。
1.初识
<groupId>com.strivelearn</groupId>
<artifactId>hello-world</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>jar</packaging>
- 1.groupId
groupId定义了项目属于哪个组,这个组往往和项目所在的组织或公司存在关联。
- 2.artifactId
定义了Maven项目在组中唯一的ID。(格式:产品线名-模块名)。
- 3.version
指的项目当前的版本(1.0-SNAPSHOT)SNAPSHOT指的是快照,说明该项目还处于开发中,是不稳定的版本。版本命名方式:主版本号.次版本号.修订号。(起始版本号:1.0.0)
- 主版本号:产品方向改变,或者大规模API不兼容,或者架构不兼容升级。
- 次版本号:保持相对兼容性,增加主要功能特性,影响范围极小的API不兼容修改。
- 修订号:保持完全兼容,修复BUG,新增次要功能特性。
2.编写主代码
如果实际项目开发中,需要使用到1.8的jdk,那么再使用maven进行作为项目管理的时候,一定要在pom文件里面加上compile的插件。如下:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.7.0</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
写好代码后,使用Maven进行编译,在项目根目录下运行命令:
mvn clean compile
clean:告诉Maven清理输出目录target/
compile:告诉Maven编译项目主代码,输出到target/classes目录
但是除了clean,compile,还有resources的操作。如果resources文件下有资源文件的话,会以utf-8的编码方式把资源拷贝到classes文件下。
3.编写测试代码
Maven项目中默认的测试代码目录在src/test/java。在使用idea生成项目的时候,会自动生成,并且会自动引入测试依赖的jar包(JUnit)
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
在上面依赖的代码里面有个值为test的元素scope,scope为依赖范围,其值为test代表该依赖只对测试有效。如果不声明的话,默认值为compile。代表该依赖对主代码和测试代码都有效。
在JUnit中,所有执行测试的方法都是以test开头。需要执行的测试方法都应该以@Test进行标注。测试用例编写完毕之后调用Maven命令:
mvn clean test
执行命令之后会在target/test-classes下生成二进制文件。并且会显示测试多少,通过了多少,失败了多少
4.打包和运行
pom文件中如果没有指定打包类型,使用默认的打包类型jar。执行以下命令:
mvn clean package
Maven会在打包之前执行编译、测试等操作。
这时候,虽然我们可以复制这个jar文件到其他项目的Classpath中从而使用。但是如果让其他Maven项目直接引用这个jar呢。还需要安装步骤,执行命令
mvn clean install
安装完成后,我们就可以在maven本地仓库中,看到我们项目的pom和jar
默认打包生成jar是不能够直接运行的,因为带有main方法的类信息不会加载添加到manifest中。(打开jar文件中的META-INF/MANIFEST.MF文件,将无法看到Main-Class一行)
Manifest-Version: 1.0
Archiver-Version: Plexus Archiver
Built-By: strivelearn
Created-By: Apache Maven 3.5.2
Build-Jdk: 1.8.0_151
加入maven-shade-plugin插件。通过设置 MainClass 创建一个可执行 Jar 包。
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>3.1.0</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
<configuration>
<transformers>
<transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
<mainClass>com.strivelearn.App</mainClass>
</transformer>
</transformers>
</configuration>
</execution>
</executions>
</plugin>
最终在MANIFEST.MF里有了Main-Class
Manifest-Version: 1.0
Archiver-Version: Plexus Archiver
Built-By: strivelearn
Created-By: Apache Maven 3.5.2
Build-Jdk: 1.8.0_151
Main-Class: com.strivelearn.App
这时候,可以cd到jar的根目录执行
java -jar hello-world.jar。那么就可以得到想要的结果了。
5.使用Archetype生成Maven项目
Maven项目的约定是根目录放置pom.xml文件。在src/main/java目录中放置项目的主代码,在src/test/java中放置项目的测试代码。
当我们用maven archetype来创建项目骨架的时候,这些默认的约定直接给我们搭载好了。
mvn archetype:generate