将原始模块按照功能拆分成若干个子模块,方便模块间的相互调用,接口共享
注意:分模块开发需要先针对模块功能进行设计,再进行编码。不会先将工程开发完毕,然后进行拆分
<dependency>
<groupId>com.zsgroupId>
<artifactId>maven_pojoartifactId>
<version>1.0-SNAPSHOTversion>
dependency>
此时使用指令compile编译maven_ssm会出现报错
问题:不能解决maven_02_ssm项目的依赖问题,找不到maven_03_pojo这个jar包。
原因:Maven会从本地仓库找对应的jar包,但是本地仓库又不存在该jar包所以会报错。
解决:在IDEA中是有maven_03_pojo这个项目,所以我们只需要将maven_03_pojo项目安装(install命令)到本地仓库即可
团队内部开发需要发布模块功能到团队内部可共享的仓库中(私服)
问题:项目依赖的某一个jar包,有多个不同的版本,造成类包版本冲突
特殊优先:当同级配置了相同资源的不同版本,后配置的覆盖先配置的
特殊优先: 当同级配置了相同资源的不同版本,后配置的覆盖先配置的
路径优先: 当依赖中出现相同的资源时,层级越深,优先级越低,层级越浅,优先级越高
例如:E1配的是Junit4.1,E2配的是Junit4.2,则整个工程的Junit版本是4.1
声明优先: 当资源在相同层级被依赖时,配置顺序靠前的覆盖配置顺序靠后的
D1和D2都是两度,这个时候就不能按照层级来选择,需要按照声明来,谁先声明用谁,也就是说B在C之前声明,这个时候使用的是D1,反之则为D2
通过show Dependencies可以直接查看Maven中各个坐标的依赖关系
到底是直接依赖还是间接依赖全凭自己写
问题:
解决方案:抽取一个项目,把所有的项目管理起来——聚合工程
聚合工程开发:
每个maven工程都有对应的打包方式,默认是jar,web工程打包方式是war
<?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>maven_01_parent</artifactId>
<version>1.0-RELEASE</version>
<packaging>pom</packaging>
<!--设置管理的模块名称,module顺序不重要,系统会根据依赖关系自动调整顺序。各模块都在当前pom.xml的父目录一级-->
<modules>
<module>../maven_02_ssm</module>
<module>../maven_03_pojo</module>
<module>../maven_04_dao</module>
</modules>
</project>
聚合工程中所包含的模块在进行构建时会根据模块间的依赖关系设置构建顺序,与聚合工程中模块的配置书写位置无关
参与聚合的工程无法向上感知是否参与聚合,只能向下配置哪些模块参与本工程的聚合
解决方案:继承
继承:描述的是两个工程间的关系,与java中的继承相似,子工程可以继承父工程中的配置信息,常见于依赖关系的继承。
作用:简化配置;减少版本冲突
实现:
<dependencies>
<dependency>
<groupId>org.springframeworkgroupId>
<artifactId>spring-webmvcartifactId>
<version>5.2.10.RELEASEversion>
dependency>
.....
dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>junitgroupId>
<artifactId>junitartifactId>
<version>4.12version>
<scope>testscope>
dependency>
dependencies>
......
dependencyManagement>
<parent>
<groupId>com.zsgroupId>
<artifactId>maven_parentartifactId>
<version>1.0-SNAPSHOTversion>
<relativePath>../maven_parent/pom.xmlrelativePath>
parent>
<dependency>
<groupId>com.alibabagroupId>
<artifactId>druidartifactId>
dependency>
- 子工程中使用父工程中的可选依赖时,仅需要提供群组id和项目id,无需提供版本,版本由父工程统一提供, 避免版本冲突
- 子工程中还可以定义父工程中没有定义的依赖关系
问题:
前面我们已经在父工程中的dependencyManagement标签中对项目中所使用的jar包版本进行了统一的管理,但是如果在标签中有如下的内容:
如果我们现在想更新Spring的版本,你会发现我们依然需要更新多个jar包的版本,这样的话还是有可能出现漏改导致程序出问题,而且改起来也是比较麻烦。
思考:参考java基础所学习的变量,声明一个变量,在其他地方使用该变量,当变量的值发生变化后,所有使用变量的地方,就会跟着修改
解决方案:属性
<properties>
<spring.version>5.2.10.RELEASEspring.version>
<junit.version>4.12junit.version>
<mybatis-spring.version>1.3.0mybatis-spring.version>
properties>
<dependency>
<groupId>org.springframeworkgroupId>
<artifactId>spring-coreartifactId>
<version>${spring.version}version>
dependency>
<dependency>
<groupId>org.springframeworkgroupId>
<artifactId>spring-webmvcartifactId>
<version>${spring.version}version>
dependency>
<dependency>
<groupId>org.springframeworkgroupId>
<artifactId>spring-jdbcartifactId>
<version>${spring.version}version>
dependency>
......
问题:现在已经能够通过Maven来集中管理Maven中依赖jar包的版本。如果想让Maven对于属性的管理范围能更大些,比如我们之前项目中的jdbc.properties,这个配置文件中的属性,能不能也来让Maven进行管理呢?
实现:
<properties>
<jdbc.url>jdbc:mysql://127.1.1.1:3306/ssm_dbjdbc.url>
properties>
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=${jdbc.url}
jdbc.username=root
jdbc.password=root
<build>
<resources>
<resource>
<directory>../maven_ssm/src/main/resourcesdirectory>
<filtering>truefiltering>
resource>
resources>
build>
directory路径前要添加…/的原因是maven_02_ssm相对于父工程的pom.xml路径是在其上一层的目录中,所以需要添加。
父工程配置文件加载多个项目的属性:
方式一:(项目多的话,不推荐)
<build>
<resources>
<resource>
<directory>../maven_02_ssm/src/main/resourcesdirectory>
<filtering>truefiltering>
resource>
<resource>
<directory>../maven_03_pojo/src/main/resourcesdirectory>
<filtering>truefiltering>
resource>
...
resources>
build>
方式二:(推荐)
<build>
<resources>
<resource>
<directory>${project.basedir}/src/main/resourcesdirectory>
<filtering>truefiltering>
resource>
resources>
build>
解决方案1:在maven_02_ssm项目的src\main\webapp\WEB-INF\添加一个web.xml文件(文件空的也行),这种方法不规范,但是推荐使用
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1">
web-app>
解决方案2: maven_02_ssm配置maven打包war时,忽略web.xml检查,failOnMissingWebXml:
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.pluginsgroupId>
<artifactId>maven-war-pluginartifactId>
<version>3.2.3version>
<configuration>
<failOnMissingWebXml>falsefailOnMissingWebXml>
configuration>
plugin>
plugins>
build>
测试,将maven_ssm项目进行打包,然后观察打包结果中最终生成的内容是否为Maven中配置的内容
上面我们所使用的都是Maven的自定义属性,${project.basedir}属于Maven的内置系统属性
工程版本:
SNAPSHOT(快照版本)
RELEASE(发布版本)
发布版本:
我们平常都是在自己的开发环境进行开发,当开发完成后,需要把开发的功能部署到测试环境供测试人员进行测试使用,等测试人员测试通过后,我们会将项目部署到生成环境上线使用。
问题:不同环境的配置是不相同的,如不可能让三个环境都用一个数据库,所以就会有三个数据库的url配置。
解决方案:maven提供配置多种环境的设定,帮助开发者在使用过程中快速切换环境
实现:
<profiles>
<profile>
<id>env_depid>
<properties>
<jdbc.url>jdbc:mysql://127.1.1.1:3306/ssm_dbjdbc.url>
properties>
<activation>
<activeByDefault>trueactiveByDefault>
activation>
profile>
<profile>
<id>env_proid>
<properties>
<jdbc.url>jdbc:mysql://127.2.2.2:3306/ssm_dbjdbc.url>
properties>
profile>
<profile>
<id>env_testid>
<properties>
<jdbc.url>jdbc:mysql://127.3.3.3:3306/ssm_dbjdbc.url>
properties>
profile>
profiles>
//mvn 指令 -P 环境定义id
mvn install -P pro_env
问题:在多环境开发中,执行install安装指令的时候,Maven都会按照顺序从上往下依次执行,每次都会执行测试test
不需要测试的情况:
三种方式跳过测试:
方式一:使用命令跳过测试
mvn 指令 -D skipTests
范例:mvn install -D skipTests
执行的项目构建指令必须包含测试test生命周期,否则无效果。例如执行compile生命周期,不经过test生命周期
方式二:maven禁用test按钮
方式三:细粒度控制跳过测试
<build>
<plugins>
<plugin>
<artifactId>maven-surefire-pluginartifactId>
<version>2.12.4version>
<configuration>
<skipTests>falseskipTests>
<includes>
<include>**/User*Test.javainclude>
includes>
<excludes>
<exclude>**/BookServiceTest.javaexclude>
excludes>
configuration>
plugin>
plugins>
build>
- skipTests:如果为true,则跳过所有测试,如果为false,则不跳过测试
- excludes:哪些测试类不参与测试,即排除,针对skipTests为false来设置的
- includes: 哪些测试类要参与测试,即包含,针对skipTests为true来设置的
私服是一台独立的服务器,用于解决团队内部的资源共享与资源同步问题
私服产品Nexus:Sonatype公司的一款maven私服产品
下载地址:Download
配置本地Maven对私服的访问权限
在本地Maven的配置文件settings.xml中进行配置
<servers>
<server>
<id>zs-snapshotid>
<username>adminusername>
<password>adminpassword>
server>
<server>
<id>zs-releaseid>
<username>adminusername>
<password>adminpassword>
server>
servers>
<mirrors>
<mirror>
<!--配置仓库组的ID-->
<id>maven-public</id>
<!--*代表所有内容都从私服获取-->
<mirrorOf>*</mirrorOf>
<!--私服仓库组maven-public的访问路径-->
<url>http://localhost:8081/repository/maven-public/</url>
</mirror>
</mirrors>
为了避免阿里云Maven私服地址的影响,建议先将之前配置的阿里云Maven私服镜像地址注释掉,等练习完后,再将其恢复
工程上传到私服服务器设置:
<distributionManagement>
<repository>
<id>zs-releaseid>
<url>http://localhost:8081/repository/itheima-release/url>
repository>
<snapshotRepository>
<id>zs-snapshotid>
<url>http://localhost:8081/repository/itheima-snapshot/url>
snapshotRepository>
distributionManagement>
要发布的项目都需要配置分配管理distributionManagement标签,要么在自己的pom.xml中配置,要么在其父项目中配置,然后子项目中继承父项目即可。
私服访问中央服务器设置