Maven阅读之坐标与依赖

Maven坐标

像数学中横坐标,纵坐标一样,两个坐标确定一个点,甚至是三维的,三点确定一个点,Maven也有相应的定义规则:任何一个构件在Maven中都有唯一标识,Maven坐标元素有groupId,artifactId,version,packaging,classifier,当我们提供正确的坐标,我们就能得到对应的构件。

坐标定义

groupId: 定义了当前Maven项目隶属的实际项目。在实际运用中,一个组织中有几个项目也很正常,这种情况下,groupId应该定义到模块级别。它的表示方式跟java包名表示方式类似,通常与域名反转一一对应,如公司apple公司,banana项目,groupId则变现为com.apple.banana

artifactId: 定义了实际项目中的一个Maven项目或者模块,书中推荐做法是,以实际项目名称作为前缀,默认情况下,Maven生成的构件,会以artifactId开头,如nexus-indexer-2.0.jar,这样命名就能够容易区分开来了。

version: 表示当前项目的版本

packaging: 表示项目的打包的方式,默认为jar

classifier: 该元素是用来帮助定义构建输出的一些附属构件,附属构件与主构件对应,如上面的nexus-indexer-2.0.jar,项目可能通过一些插件生成nexus-indexer-2.0-javadoc.jar这样的一些附属构件,注意不能直接定义项目的classifier,因为附属构件不是项目默认生成的,而是附加的插件帮助生成。

Maven依赖

    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">

  4.0.0

 

    com.fbb

    fbbParent

    1.0

 

  com.fbb

  fbb-admin

  1.0

  war

  fbb-admin Maven Webapp

  http://maven.apache.org

 

    UTF-8

 

 

   

      junit

      junit

      3.8.1

      test

   

   

        com.fbb

        fbb-web

        1.0

   

   

        com.fbb

        fbb-service

        1.0

   

 

 

    fbb-admin

   

       

            maven-war-plugin

            2.5

           

                node_modules\** 

           

       

   

 

上面的pom.xml文件,是一个项目的总体定义,其中 为项目父标签,groupId,artifactId,version,packaging,name,url等元素定义了fbb-admin这个项目的基本信息,标签标示本项目的依赖,通过项目的依赖关系定义,引进项目的依赖。

groupId,artifactId,version: 依赖的基本坐标,项目依靠坐标才能找到依赖。

type: 依赖的类型,默认为jar

scope: 打包的范围,比如test,表示测试时候会编译该代码。

optional,以及exclusions标签: 一个标记依赖是否可选,一个表示用来排除传递性依赖。

依赖范围

在实际项目中,编译主项目代码是一套classpath,编译和测试又是另外一套classpath,实际项目运行的时候又是另外一套classpath。依赖范围也就是上面讲到的标签来进行控制。

compile: 编译依赖范围,默认使用此范围,此范围下三套classpath都有效

test: 测试依赖范围,只对测试classpath有效。在编译主代码或者运行项目的时候无法使用此类依赖。

provided: 已提供依赖范围,对编译和测试的classpath有效。典型例子,servlet-api运行时容器已经提供,所以不需要重复引进此依赖

runtime: 运行时依赖范围,对测试和运行classpath有效,编译主代码无效。

system: 系统依赖范围,和provided的范围一样,但是使用此依赖时必须通过systemPath元素显示地指定依赖文件的路径,由于此类依赖不是通过Maven仓库解析,而且往往与本机系统绑定,需要谨慎使用。

Maven通过一系列的坐标来确定唯一的项目位置,通过依赖坐标,引进项目之间的依赖关系。以目前自己的见解,各个开发人员公用一套pom文件,统一了开发的版本,不会出现因为某个依赖的接口因为版本的变更出现不兼容问题,使用Maven更好地去帮助我们管理好我们的项目仓库。

你可能感兴趣的:(Maven阅读之坐标与依赖)