依赖管理
依赖配置
- 依赖就是当前项目运行所需要的jar包
在idea中新建三个模块,project01,project02,project03;在三者的dependencies中配置依赖,分别配置log4j的1.2.12;1.2.13;1.2.14
eg:(01中)
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.12</version>
</dependency>
在右侧的Maven面板刷新,三个依赖都出现
依赖传递
在project02的依赖中添加project03(将项目3的地址粘贴即可)
eg:
<dependency>
<groupId>org.example</groupId>
<artifactId>project03</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
此时刷新,发现右侧的2的依赖中有3,并且能看到3的依赖1.2.14!
此时在3的依赖中再加一个junit,刷新,也可以在2中看到
这就是依赖传递!
- 直接依赖:在当前项目中通过依赖配置建立的依赖关系。
- 间接依赖:被添加的依赖资源如果依赖其他资源,当前项目间接依赖其他资源。
依赖传递冲突问题
- 路径优先:当依赖中出现相同资源时,层级越深,优先级越低。
- 声明优先:当资源在相同层级被依赖时,配置顺序靠前的覆盖配置顺序靠后的。(谁现在dependencise中出现,谁生效)
可选依赖
- 可选依赖指对外隐藏当前所依赖的资源-------不透明
<optional>true</optional>
排除依赖
- 排除依赖指主动断开依赖资源,被排除的资源无需指定版本
eg:在项目2中对3的依赖下方增加指令
<dependency>
<groupId>org.example</groupId>
<artifactId>project03</artifactId>
<version>1.0-SNAPSHOT</version>
<exclusions> <!--要排除的依赖,无需指定version-->
<exclusion>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
</exclusion>
</exclusions>
</dependency>
依赖范围
在dependency中
<scope>compile/provided/runtime/system/test</scope>
- 依赖的jar默认范围在任意位置使用,可以通过scope标签设定其作用范围
- 作用范围:
- main文件夹内
- test文件夹内
- 是否参与打包
scope | 主代码 | 测试代码 | 打包 | 范例 |
compile | Y | Y | Y | log4j |
test | Y | junit | ||
provided | Y | Y | servlet-api | |
runtime | Y | jbdc |
在project02的依赖中添加
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.3</version>
<scope>compile/provided/runtime/system/test</scope>
</dependency>
*/选择不同的scope观察右侧依赖
在project01的依赖中添加project02
<dependency>
<groupId>org.example</groupId>
<artifactId>project02</artifactId>
<version>1.0-SNAPSHOT</version>
<scope>compile/provided/runtime/test</scope>
</dependency>
*/选择不同的scope观察右侧依赖
结果:横坐标project01/纵坐标project02
compile | test | provided | runtime | |
compile | compile | test | provided | runtime |
test | / | / | / | / |
provided | / | / | / | / |
runtime | runtime | test | provided | runtime |
生命周期与插件
项目构建生命周期
…----->compile----->test-compile------->test------->package------->install----->…
- Maven对项目构建的生命周期划分为三套:
- clean:清理工作
- pre-clean
- clean
- post-clean
- default:核心工作,eg:编译,测试,打包,部署等…
validate(校验) | 校验项目是否正确并且所有必要的信息可以完成项目的构建过程。 |
initialize(初始化) | 初始化构建状态,比如设置属性值。 |
generate-sources(生成源代码) | 生成包含在编译阶段中的任何源代码。 |
process-sources(处理源代码) | 处理源代码,比如说,过滤任意值。 |
generate-resources(生成资源文件) | 生成将会包含在项目包中的资源文件。 |
process-resources (处理资源文件) | 复制和处理资源到目标目录,为打包阶段最好准备。 |
compile(编译) | 编译项目的源代码。 |
process-classes(处理类文件) | 处理编译生成的文件,比如说对Java class文件做字节码改善优化。 |
generate-test-sources(生成测试源代码) | 生成包含在编译阶段中的任何测试源代码。 |
process-test-sources(处理测试源代码) | 处理测试源代码,比如说,过滤任意值。 |
generate-test-resources(生成测试资源文件) | 为测试创建资源文件。 |
process-test-resources(处理测试资源文件) | 复制和处理测试资源到目标目录。 |
test-compile(编译测试源码) | 编译测试源代码到测试目标目录. |
process-test-classes(处理测试类文件) | 处理测试源码编译生成的文件。 |
test(测试) | 使用合适的单元测试框架运行测试(Juint是其中之一)。 |
prepare-package(准备打包) | 在实际打包之前,执行任何的必要的操作为打包做准备。 |
package(打包) | 将编译后的代码打包成可分发格式的文件,比如JAR、WAR或者EAR文件。 |
pre-integration-test(集成测试前) | 在执行集成测试前进行必要的动作。比如说,搭建需要的环境。 |
integration-test(集成测试) | 处理和部署项目到可以运行集成测试环境中。 |
post-integration-test(集成测试后) | 在执行集成测试完成后进行必要的动作。比如说,清理集成测试环境。 |
verify (验证) | 运行任意的检查来验证项目包有效且达到质量标准。 |
install(安装) | 安装项目包到本地仓库,这样项目包可以用作其他本地项目的依赖。 |
deploy(部署) | 将最终的项目包复制到远程仓库中与其他开发者和项目共享。 |
- site:产生报告,发布站点等…
- pre-site
- site
- post-site
- site-deploy
插件
- 插件于生命周期内的阶段绑定,在执行到相应的声明周期时执行对应插件功能
- 默认maven在各个生命周期上绑定有预设的功能
- 通过插件自定义其他功能
在官网上的maven plugins中寻找需要的插件
例如我这里想用source插件,找到位置,复制其坐标(各种id)
在build补充:
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId> <!--坐标-->
<artifactId>maven-source-plugin</artifactId>
<version>2.2.1</version>
<executions> <!--执行-->
<execution>
<goals>
<goal>jar</goal><!--在此位置执行-->
</goals>
<phase>generate-test-resources</phase><!--在此阶段执行-->
</execution>
</executions>
</plugin>
</plugins>
</build>