【Maven】属性scope依赖作用范围详解

文章目录

    • 前言
    • scope取值和作用表
    • 详解
      • compile
      • provided
      • system
      • runtime
      • test
      • import

前言

Maven中使用 scope 来指定当前包的依赖范围和依赖的传递性。常见的可选值有:compile,provided,runtime,test, syste,import 等。scope 主要是用在 pom.xml 文件中的依赖定义部分,例如:

<dependency>
   <groupId>javax.servletgroupId>
   <artifactId>javax.servlet-apiartifactId>
   <version>4.0.1version>
   <scope>providedscope>
dependency>

scope取值和作用表

scope取值 有效范围 依赖传递 是否打入jar包 例子
compile all spring-core
provided compile,test servlet-api
system compile,test
runtime runtime,test JDBC驱动
test test JUnit
import

详解

compile

为默认的依赖有效范围。定义依赖关系没有指定依赖有效范围,默认采用该依赖有效范围;

此种依赖,在编译、运行、测试时均有效,会以依赖传递,打入jar包;

provided

在编译、测试时有效,但是在运行时无效。provided意味着打包的时候不会打入jar包,别的设施(Web Container)会提供。

事实上该依赖理论上可以参与编译,测试,运行等周期。相当于compile,但是在打包阶段做了exclude的动作。

例如:servlet-api,运行项目时,容器已经提供,就不需要打入jar包了。

说到provided,这里就要说到 dependency 下的子标签 optional ,如果一个依赖的 optional 设置为true,则该依赖在打包的时候不会被打进jar包,同时不会通过依赖传递传递到依赖该项目的工程;例如:x

依赖B,B由依赖于A(x->B->A),则A中设置 optional 为true的依赖不会被传递到x中。

两者区别:

1、为true 表示某个依赖可选,该依赖是否使用都不会影响服务运行;

2、provided的在目标容器中已经提供了这个依赖,无需在提供

system

system依赖不是由maven仓库管理,而是本地的jar包,因此必须配合systemPath标签来指定本地的jar包所在全路径。这类jar包默认会参与编译、测试,但是不会被参与打包阶段。如果也想打包进去的话,需要在插件里做配置true;

//引用本地jar包
<dependency>
    <groupId>com.mytestgroupId>
    <artifactId>testartifactId>
    <version>1.0version>
    <scope>systemscope>
    <systemPath>${pom.basedir}/lib/test-1.0.jarsystemPath>
dependency>

由于此类依赖不是通过Maven仓库解析的,而且往往与本机系统绑定,可能造成构建的不可移植,因此应该谨慎使用。

runtime

在运行、测试时有效,但是在编译代码时无效,打入jar包;
例如:JDBC驱动实现,项目代码编译只需要JDK提供的JDBC接口,只有在测试或运行项目时才需要实现上述接口的具体JDBC驱动。

test

只在测试时有效,包括测试代码的编译,执行,不会打入jar包;例如:JUnit。

import

import 只能在pom文件的中使用,从而引入其他的pom文件中引入依赖;
如:在Spring boot 项目的POM文件中,我们可以通过在POM文件中继承 Spring-boot-starter-parent来引
用Srping boot默认依赖的jar包,如下:

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.0.1.BUILD-SNAPSHOT</version>
</parent>

但是,通过上面的parent继承的方法,只能继承一个 spring-boot-start-parent。实际开发中,用户很可能需要继承自己公司的标准parent配置,这个时候可以使用 scope=import 来实现多继承。代码如下:

     <dependencyManagement>
         <dependencies>
             <dependency>
                 
                 <groupId>org.springframework.bootgroupId>
                 <artifactId>spring-boot-dependenciesartifactId>
                 <version>2.0.1.BUILD-SNAPSHOTversion>
                 <type>pomtype>
                 <scope>importscope>
            dependency>
        dependencies>
    dependencyManagement>

通过上面方式,就可以获取spring-boot-dependencies.2.0.1.BUILD-SNAPSHOT.pom文件中dependencyManagement配置的jar包依赖。如果要继承多个,可以在dependencyManagement中添加,如:

     <dependencyManagement>
         <dependencies>
             
             <dependency>
                 <groupId>org.springframework.datagroupId>
                 <artifactId>spring-data-releasetrainartifactId>
                 <version>Fowler-SR2version>
                 <type>pomtype>
                 <scope>importscope>
            dependency>
            <dependency>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-dependenciesartifactId>
                <version>2.0.1.BUILD-SNAPSHOTversion>
                <type>pomtype>
                <scope>importscope>
            dependency>
        dependencies>
    dependencyManagement>

另外:【Maven】jar包冲突原因与最优解决方案

你可能感兴趣的:(maven,maven,java)