一、Maven内置隐式变量

  • ${basedir} 项目根目录
  • ${project.build.directory} 构建目录,缺省为target
  • ${project.build.outputDirectory} 构建过程输出目录,缺省为target/classes
  • ${project.build.finalName} 产出物名称,缺省为${project.artifactId}-${project.version}
  • ${project.packaging} 打包类型,缺省为jar
  • ${project.xxx} 当前pom文件的任意节点的内容

参考链接 Maven内置隐式变量

示例:

<dependency>
         <groupId>${project.groupId}</groupId>
         <artifactId>user-log</artifactId>
         <version>${project.version}</version>
     </dependency>

二、Maven依赖

 scope 是用来限制 dependency 依赖的作用范围的,影响 maven 项目在各个生命周期时导入的 package 的状态,主要管理依赖的部署。

scope 的作用范围:

(1)compile:默认值,适用于所有阶段(表明该 jar 包在编译、测试以及运行三个范围中都有效),并且会随着项目一起发布。编译的时候加入依赖。打包的时候也加入依赖。

(2)test:只在测试时使用,用于编译和运行测试代码,不会随项目发布。

(3)runtime:无需参与项目的编译,不过后期的测试和运行周期需要其参与,与 compile 相比,跳过了编译。如 JDBC 驱动,适用运行和测试阶段。

(4)provided:编译和测试时有效,但是该依赖在运行时由服务器提供,所以打包时不应该被包含进去,否则会jar包冲突。如 servlet-api。编译的时候加入依赖。打包的时候不加入依赖。

(5)system:类似 provided,需要显式提供包含依赖的jar,不会从 maven 仓库下载,而是从本地文件系统获取,需要添加 systemPath 的属性来定义路径。

三、依赖传递

  • scope的值为test时,依赖不会被传递。
  • 直接依赖&间接依赖,当出现间接依赖时,首先出现的包会被依赖

项目A依赖于包jar1.0,项目B依赖于包jar2.0,项目C依赖于项目A和B,那么项目C到底是依赖于哪个版本呢?

答案:如果包jar1.0与包jar2.0是同一级别的依赖,依赖于先出现的版本。比如先引入依赖A,则项目C依赖于jar1.0,项目C和jar1.0的关系是间接依赖。

  • 同一级别的依赖,首先出现的包会被依赖;依赖级别不同,依赖于第一级依赖。

四、依赖排除<exclusion>...</exclusion>

<dependency>
	<groupId>${project.groupId}</groupId>
	<artifactId>user-log</artifactId>
	<version>${project.version}</version>
	<!-- 依赖排除 -->
	<exclusions>
		<exclusion>
			<groupId>commons-logging</groupId>
			<artifactId>commons-logging</artifactId>
		</exclusion>
	</exclusions>
</dependency>