继承
为什么需要继承?
在Maven中,非compile范围的依赖不能在依赖中传递,所以需要每个工程单独配置非compile范围的依赖,就比如我们junit依赖。如果现在各个工程的junit版本都需要是4.9,那么这个时候各个工程手动去修改无疑是不可取的,使用继承就可以将这样的依赖信息统一到父工程中进行统一管理。
1. 创建父工程,一般都使用Java工程,唯一需要注意的是打包方式为pom。
2. 在父工程中配置jar包的依赖
<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.wage.maven</groupId>
<artifactId>Parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>pom</packaging>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.9</version>
<scope>test</scope>
</dependency>
</dependencies>
</dependencyManagement>
</project>
3. 在子工程中引用父工程
<?xml version="1.0" ?>
<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 和 version 与父工程一致,则可以省略 子工程坐标groupId 和 version 声明
-->
<!-- <groupId>com.wage.maven</groupId> -->
<artifactId>Hello</artifactId>
<!-- <version>0.0.1-SNAPSHOT</version> -->
<parent>
<!-- 引用父工程的坐标
如果父工程的坐标 groupId 和 version 与父工程一致,则可以省略 子工程坐标groupId 和 version 声明
-->
<groupId>com.wage.maven</groupId>
<artifactId>Parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
<!-- 配置当前工程目录到父工程的pom.xml文件的相对路径 -->
<relativePath>../Parent/pom.xml</relativePath>
</parent>
<name>Hello</name>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
</dependency>
</dependencies>
</project>
聚合
为什么需要聚合?将一个项目拆分成多个个工程之后,需要手动逐个安装到仓库后才能够生效,修改后每个工程都需要单独的进行maven的各项操作。所以聚合之后,就可以对聚合的所有的工程统一的执行maven指令,比如打包,安装…
聚合的配置非常简单:
<!-- 聚合 -->
<modules>
<module>../Hello</module>
<module>../HelloFriend</module>
<module>../MakeFriends</module>
<module>../HelloWorld</module>
<module>OurFriend</module>
</modules>
注意点:需要在pom打包方式的工程中配置聚合。