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">
上面的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更好地去帮助我们管理好我们的项目仓库。