美文网首页
Maven阅读之坐标与依赖

Maven阅读之坐标与依赖

作者: 超级大鸡腿 | 来源:发表于2019-01-21 16:38 被阅读0次

    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依赖

    <?xml version="1.0"?>

    <project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"

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

      <modelVersion>4.0.0</modelVersion>

      <parent>

        <groupId>com.fbb</groupId>

        <artifactId>fbbParent</artifactId>

        <version>1.0</version>

      </parent>

      <groupId>com.fbb</groupId>

      <artifactId>fbb-admin</artifactId>

      <version>1.0</version>

      <packaging>war</packaging>

      <name>fbb-admin Maven Webapp</name>

      <url>http://maven.apache.org</url>

      <properties>

        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

      </properties>

      <dependencies>

        <dependency>

          <groupId>junit</groupId>

          <artifactId>junit</artifactId>

          <version>3.8.1</version>

          <scope>test</scope>

        </dependency>

        <dependency>

            <groupId>com.fbb</groupId>

            <artifactId>fbb-web</artifactId>

            <version>1.0</version>

        </dependency>

        <dependency>

            <groupId>com.fbb</groupId>

            <artifactId>fbb-service</artifactId>

            <version>1.0</version>

        </dependency>

      </dependencies>

      <build>

        <finalName>fbb-admin</finalName>

        <plugins>

            <plugin>

                <artifactId>maven-war-plugin</artifactId>

                <version>2.5</version>

                <configuration>

                    <warSourceExcludes>node_modules\**</warSourceExcludes> 

                </configuration>

            </plugin>

        </plugins>

      </build>

    </project>

    上面的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阅读之坐标与依赖

          本文链接:https://www.haomeiwen.com/subject/noncjqtx.html