Maven POM中的各种scope

  1. compile:默认的scope。任何定义在compile scope下的依赖将会在所有的class paths下可用。maven工程会将其打包到最终的artifact中。如果你构建一个WAR类型的artifact,那么在compile scope下引用的JAR文件将会被集成到WAR文件内。

  2. provided:这个scope假定对应的依赖会由运行这个应用的JDK或者容器来提供。最好的例子就是servlet API。任何在provided scope下定义的依赖在构建时的类路径里是可用的,但是不会被打包到最终的artifact中。如果是一个WAR的文件,servlet API在构建时的类路径里是可用的,但是并不会被打包到WAR文件中。

  3. runtime:在runtime scope下定义的依赖只会在运行期可用,而在构建期的类路径下不可用。这些依赖将会被打包到最终的artifact中。比如你有一个基于web的应用需要在运行时访问MySQL数据库。你的代码没有任何MySQL数据库驱动的硬依赖。你的代码仅仅是基于JDBC API来编写,在构建期并不需要MySQL数据库驱动。然而,在运行期,就需要相应的驱动来操作MySQL数据库了。因此,这个驱动应该被打包到最终的artifact中。

  4. test:只用于测试变异的依赖(比如JUnit),execution必须定义在test scope下。这些依赖不会被打包到最终的artifact中。

  5. system:于provided scope很像。唯一的区别在于,在system scope中,你需要告诉Maven如何去找到这个依赖。如果你要引用的依赖在Maven仓库中不存在时,就可以用这个scope。不推荐使用system依赖。

  6. import:从其它的pom文件中导入依赖设置

使用import scope解决maven继承(单)问题

测试环境 maven 3.3.9

想必大家在做SpringBoot应用的时候,都会有如下代码:


    org.springframework.boot
    spring-boot-starter-parent
    1.3.3.RELEASE

继承一个父模块,然后再引入相应的依赖
我们知道Maven的继承和Java的继承一样,是无法实现多重继承的,如果10个、20个甚至更多模块继承自同一个模块,那么按照我们之前的做法,这个父模块的dependencyManagement会包含大量的依赖。如果你想把这些依赖分类以更清晰的管理,那就不可能了,import scope依赖能解决这个问题。你可以把dependencyManagement放到单独的专门用来管理依赖的pom中,然后在需要使用依赖的模块中通过import scope依赖,就可以引入dependencyManagement。

例如可以写这样一个用于依赖管理的pom:


    4.0.0
    com.test.sample
    base-parent1
    pom
    1.0.0-SNAPSHOT
    
        
            
                junit
                junit
                4.8.2
            
            
                log4j
                log4j
                1.2.16
            
        
    

然后我就可以通过非继承的方式来引入这段依赖管理配置


    
        
            com.test.sample
            base-parent1
            1.0.0-SNAPSHOT
            pom
            import
        
    

 

    junit
    junit


    log4j
    log4j

注意:import scope只能用在dependencyManagement里面

这样,父模块的pom就会非常干净,由专门的packaging为pom来管理依赖,也契合的面向对象设计中的单一职责原则。此外,我们还能够创建多个这样的依赖管理pom,以更细化的方式管理依赖。这种做法与面向对象设计中使用组合而非继承也有点相似的味道。

那么,如何用这个方法来解决SpringBoot的那个继承问题呢?

配置如下:


    
        
            org.springframework.boot
            spring-boot-dependencies
            1.3.3.RELEASE
            pom
            import
        
    

 

    
        org.springframework.boot
        spring-boot-starter-web
    

这样配置的话,自己的项目里面就不需要继承SpringBoot的module了,而可以继承自己项目的module了。

你可能感兴趣的:(Maven POM中的各种scope)