dependencies 标签下只会有一个 dependency,dependency 作用于我们引用哪些 jar 来给我们提供更多的技术支持。一般用法:
<dependencies>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-pool2</artifactId>
<version>2.7.0</version>
</dependency>
</dependencies>
scop
控制 dependency(依赖) 的使用范围。通俗的讲,就是控制 Jar 包在哪些范围被加载和使用。使用方式如下:
<dependency>
<groupId>com.giant</groupId>
<artifactId>giant-core-security</artifactId>
<version>1.0-SNAPSHOT</version>
<scope>compile</scope>
</dependency>
scop 一共有 6 个值可以使用:
-
compile(默认值)
如果没有指定 scope 值,该元素的默认值为 compile。被依赖(giant-core-securit)jar 需要参与到当前项目的编译,测试,打包,运行等阶段。打包的时候通常会包含被依赖(giant-core-securit)jar。 -
provided
被依赖 jar 理论上可以参与编译、测试、运行等阶段,相当于 compile,但是在打包阶段做了exclude(排除) 的动作。例如, 如果我们在开发一个应用,在编译时我们需要依赖 xxxx.jar,但是在运行时我们不需要该 jar 包,因为这个 jar 包已由应用服务器或项目本身提供该依赖,此时我们需要使用 provided 进行范围修饰。 -
runtime
表示被依赖 jar 无需参与项目的编译阶段,但是会参与到项目的测试和运行阶段。与 compile 相比,被依赖 jar 无需参与项目的编译。适用场景:例如,在编译的时候我们不需要 JDBC API 的 jar 包,而在运行的时候我们才需要 JDBC 驱动包。 -
test
表示被依赖项目仅仅参与测试相关的工作,包括测试代码的编译,执行。适用场景:例如,Junit 测试。 -
system
system 元素与 provided 元素类似,但是被依赖 jar 不会从 maven 仓库中查找,而是从本地系统中获取,systemPath 元素用于制定本地系统中 jar 文件的路径。例如:
<dependency>
<groupId>sleepycat</groupId>
<artifactId>je</artifactId>
<version>7.0.6</version>
<scope>system</scope>
<systemPath>${project.basedir}/lib/je-7.0.6.jar</systemPath>
</dependency>
- import
它只使用在<dependencyManagement>
中,表示从其它的 pom 中导入 dependency 的配置,例如(B 项目导入 A 项目中的包配置)。众所周知,当我们创建一个 SpringBoot 项目时,我们一定会写一个<parent>
来继承 spring 所提供的所有依赖,但如果我又想使用 spring 提供的依赖,又想继承我自己的项目,此时 import 就有了用武之地
# 普通 SpringBoot 依赖
<?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.2.6.RELEASE</version>
<relativePath/>
</parent>
<groupId>com.giant</groupId>
<artifactId>station</artifactId>
<version>${project-version}</version>
<packaging>pom</packaging>
<properties>
<project-version>1.0.0</project-version>
</properties>
</project>
# 更换继承项目,并使用springboot 依赖
<?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>com.giant.parent</groupId>
<artifactId>boot-parent</artifactId>
<version>1.0-SNAPSHOT</version>
<relativePath/>
</parent>
<groupId>com.giant</groupId>
<artifactId>station</artifactId>
<version>${project-version}</version>
<packaging>pom</packaging>
<properties>
<project-version>1.0.0</project-version>
</properties>
<!-- spring boot 依赖 -->
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.6.RELEASE</version>
<!-- 需要指明时pom还是jar -->
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
</project>
optional
optional 是maven 依赖 jar 时的一个选项,表示该依赖是可选的,不会被依赖传递。例如:B依赖了日志框架 logback、log4j、apache commons log,这时候 A 引用 B 的 jar,因为 maven 有依赖传递机制,那么 A 项目就会有 3 个 jar 包,logback、log4j、apache commons log。实际上我们一般只会在项目中使用一种日志框架,那么我们项目中就会有多余的依赖,当这种情况时越来越多时,最后整个项目的 jar 包就有很多的多余依赖,导致项目很臃肿。
对于这种情况,我们只要在 B 项目中把 logback、log4j、apache commons log 设置成<optional>true</optional>
的即可。这时候A项目依赖B的时候,项目中不会有 logback、log4j、apache commons log 相关 jar 包,可以根据情况自行选择一个即可。
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
exclusions
用于排除依赖项中,不需要添加的 jar,或者使用自己版本的 jar 而不适用其他人所提供的 jar。如:引用的 spring-boot-starter-data-redis 会帮我们依赖 slf4j-api,但它使用的版本被爆出了 bug,那我要升级到更高版本,引入自己选中的版本。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<version>2.2.6.RELEASE</version>
<exclusions>
<!-- 排除spring-boot-starter-data-redis自带的 slf4j -->
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
</exclusions>
</dependency>
<!-- 引用更改版本的slf4j -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.36</version>
</dependency>
网友评论