分模块设计
- 为什么?将项目按照功能拆分成诺干子模块,方便项目的管理维护,也方便模块间相互调用,资源共享
实践
步骤
- 创建maven模块tlias-pojo,存放实体类,创建maven模块tlias-utils,存放相关工具类
-
将tlias-pojo依赖配置
XML<?xml version="1.0" encoding="UTF-8"?> <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.itheima</groupId> <artifactId>tlias-pojo</artifactId> <version>1.0-SNAPSHOT</version> <properties> <maven.compiler.source>11</maven.compiler.source> <maven.compiler.target>11</maven.compiler.target> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> </properties> <dependencies> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.32</version> </dependency> </dependencies> </project>
-
将tlias-utils依赖配置
XML<?xml version="1.0" encoding="UTF-8"?> <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.itheima</groupId> <artifactId>tlias-utils</artifactId> <version>1.0-SNAPSHOT</version> <properties> <maven.compiler.source>11</maven.compiler.source> <maven.compiler.target>11</maven.compiler.target> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> </properties> <dependencies> <!--阿里云OSS--> <dependency> <groupId>com.aliyun.oss</groupId> <artifactId>aliyun-sdk-oss</artifactId> <version>3.15.1</version> </dependency> <dependency> <groupId>javax.xml.bind</groupId> <artifactId>jaxb-api</artifactId> <version>2.3.1</version> </dependency> <dependency> <groupId>javax.activation</groupId> <artifactId>activation</artifactId> <version>1.1.1</version> </dependency> <!-- no more than 2.3.3--> <dependency> <groupId>org.glassfish.jaxb</groupId> <artifactId>jaxb-runtime</artifactId> <version>2.3.3</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>2.7.5</version> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.32</version> </dependency> <!--JWT令牌--> <dependency> <groupId>io.jsonwebtoken</groupId> <artifactId>jjwt</artifactId> <version>0.9.1</version> </dependency> </dependencies> </project>
继承
概念
-
继承描述的是两个工程间的关系,与java中的继承相似,子过程可以继承父工程中的配置信息,常见于依赖关系的继承
-
作用:简化依赖配置、统一管理依赖
-
实现:<parent>.........</parent>
继承关系实现
-
创建maven模块tlias-parent,该工程为父工程,设置打包方式pom(默认jar)
XML<?xml version="1.0" encoding="UTF-8"?> <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> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.7.5</version> <relativePath/> <!-- </relativePath>--> </parent> <groupId>com.itheima</groupId> <artifactId>tlias-parent</artifactId> <version>1.0-SNAPSHOT</version> <packaging>pom</packaging> </project>
在子过程中,配置了继承关系之后,坐标的groupId是可以省略的,因为会自动继承父工程。
relativePath指定父工程的pom文件的相对位置(如果不指定,将从本地仓库/远程仓库查找该工程)
2.在子过程的pom.xml文件中,配置继承关系
若父子工程都配置了同一个依赖的不同版本,以子工程的为准
在父工程中配置各个工程共有的依赖(子工程会自动继承父工程的依赖
3.在父工程中配置各个工程共有的依赖(子工程会有自动继承父工程的依赖)
若父子工程都配置了同一个依赖的不同版本,以子工程的为准
版本锁定
- 在maven中,可以在父工程的pom文件中通过<dependencyManagement>来统一管理依赖版本
父工程
子工程
子工程引入依赖时,无需指定<version>版本号,父工程统一管理。变更依赖版本,只需在父工程中统一变更。
- 自定义属性/引用属性
聚合
-
聚合
将多个模块组织成一个整体,同时进行项目的构成。
-
聚合工程
一个不仅拥有业务功能的"空"工程(有且仅有一个pom文件)
-
作用
快速构建项目(无需工具依赖关系手动构建,直接在聚合工程上构建即可)
实践
- maven中可以通过<modules>设置当前聚合工程所包含的子模块名称
父工程(聚合工程)
XML
<modules>
<module>../tlias-pojo</module>
<module>../tlias-utils</module>
<module>../tlias-web-management</module>
</modules>
聚合工程中所包含的模块,在构建时,会自动根据模块间的依赖关系设置构建顺序,与聚合工程中模块的配置书写位置无关
继承与聚合
-
作用
-
聚合用于快速构建项目
-
继承用于简化依赖配置、统一管理依赖
-
-
相同点
-
聚合与继承的pom.xml文件打包方式均为pom,可以将两种关系制作到同一个pom文件中
-
聚合与继承均属于设计型模块关系,父模块无法感知哪些子模块继承了自己
-