版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/SunnyYoona/article/details/50593954
1. 简介
maven的世界中拥有数量非常巨大的构件,也就是平时用的一些jar,war等文件。在maven为这些构件引入坐标概念之前,我们无法使用任何一种方式来唯一标识所有这些构件。因此,当需要用到Spring Framework依赖的时候,我们一般会去Spring Framework官网寻找;当用到log4j依赖的时候,我们又会去Apache官网去寻找。这样,我们花费了大量的时间在搜索,浏览网页上。重复的搜索,浏览网页和下载jar文件,这应该交给机器去完成。机器工作必须基于预定义的规则。
Maven定义了这样一组
规则:
世界上任何一个构件都可以使用maven坐标唯一标识,maven坐标的元素包括groupId,artifactId,version,packaging,classifier。现在,只要我们提供正确的坐标元素,maven就能找到对应的构件。比如说,当需要使用java5平台上TestNG的5.8版本时,就告诉maven:"groupId=org.testing;artifactId=testing;version=5.8;classifier=jdk15",maven就会从仓库中寻找相应的构件供我们使用。也许你会奇怪,maven是从哪里下载构件的呢?答案很简单,maven内置了一个中央仓库的地址(http://repo.maven.org/maven2),该中央仓库包含了世界上大部分流行的开源项目构件,maven会在需要的时候去那里下载。
在我们开发自己项目的时候,也需要为其定义适当的坐标,只有这样,其他的项目才能引用该项目生成的构件。
2. 详解
任何一个构件都必须明确定义自己的坐标,maven坐标由groupId,artifactId,version,packaging,chassifier构成。我们还是以hello-world项目为例如下:
<groupId>com.sjf.mavendemo</groupId>
<artifactId>maven-hello-world</artifactId>
<version>1.0.0SNAPSHOT</version>
<packaging>jar</packaging>
上述代码中,坐标分别为groupId=com.sjf.mavendemo,artifactId=maven-hello-world,version=1.0.0SNAPSHOT,packaging=jar。
下面详细解释一下各个坐标元素:
- groupId : 定义当前maven项目隶属的实际项目。首先,maven项目和实际项目不一定是一对一的关系。比如SpringFramework这一实际项目,其对应的maven项目会有很多,如: spring-core,spring-context等。这是由于maven中模块的概念,因此,一个实际项目往往会被划分成很多模块。其次,groupId不应该对应项目隶属的组织或公司。原因很简单,一个组织下会有很多个实际项目,如果groupId只定义到组织级别,而后面我们会看到,artifactId只能定义maven项目(模块),那么实际项目这个层将难以定义。最后,groupId的表示方式与java包名的表示方式类似,通常与域名反向一一对应。
- artifactId : 该元素定义实际项目中的一个maven项目(模块),推荐的做法是使用实际项目名称作为artifactId前缀。比如上面实例中的artifactId是mavendemo-hello-world,使用了实际项目名mavendemo作为前缀,这样做的好处是方便寻找实际构件。在默认情况下,maven生成的构件,其文件名会以artifactId作为开头,如:mavendemo-hello-world-1.0.0.jar,使用实际项目名称作为前缀之后,就能方便从一个lib文件夹中找到某个项目的一组构件。
- version : 该元素定义maven项目当前所处的版本,如:mavendemo-hello-world-1.0.0.jar的版本是1.0.0。需要注意的是,maven定义了一套完整的版本规范,以及快照(SNAPSHOT)的概念。
- packaging : 该元素定义maven项目的打包方式。首先,打包方式通常与所生成构件的文件扩展名对应,如:mavendemo-hello-world.1.0.0.jar的packaging为jar,而使用war打包方式的maven项目,最终生成的构件会有一个.war文件,不过这不是绝对的。其次,打包方式会影响到构建的生命周期,比如jar打包和war打包会使用不同的命令。最后,当不定义packaging的时候,maven会使用默认值jar。
- classifier : 该元素用来帮助定义构建输出的一些附属构件。附属构件与主构件对应,如上例中的主构件是: mavendemo-hello-world-1.0.0.jar,该项目可能还会通过使用一些插件生成如:mavendemo-hello-world-1.0.0-javadoc.jar、mavendemo-hello-world-1.0.0-sources.jar这样一些附属构件,其包含了java文档和源代码。这时候,javadoc和sources就是这两个附属构件的classifier。这样,附属构件也就拥有了自己唯一的坐标。
注意:不能直接定义项目的classifier,因为附属构件不是项目直接默认生成的,而是由附加的插件帮助生成。
上述5个元素中,groupId,artifactId,version是必须定义的,packaging是可选的(默认为jar),而classifier是不能直接定义的。
同时,项目构件的文件名是与坐标相对应的,一般的规则为: artifactId-version[-classifier].packaging,[-classifier]表示可选。
来源于:《Maven实战》