Maven,是基于项目对象模型(POM),可以通过一小段描述信息来管理项目的构建,报告和文档的软件项目管理工具。
上面是百度百科对Maven的正式介绍,如果你是Maven初学者,我估计你看完之后心中肯定会有一万头姓草的动物奔腾而过,严重者甚至对Maven留下心理阴影。好吧,Maven到底是什么玩意?
假如你正在Eclipse下开发两个Java项目,姑且把它们称为A、B,其中A项目中的一些功能依赖于B项目中的某些类,那么如何维系这种依赖关系的呢?
在没有Maven时,需要用哪个项目中的哪些类,也就是用别人写好了的功能代码,导入jar包即可。所以这里也如此,可以将B项目打成jar包,然后在A项目的Library下导入B的jar文件,这样,A项目就可以调用B项目中的某些类了。
但这样做有几个缺陷,一是如果在开发过程中,发现B中的bug,则必须将B项目修改好,并重新将B打包并对A项目进行重编译操作。二是如果在完成A项目的开发后,为了保证A的正常运行,就需要依赖B(就像在使用某个jar包时必须依赖另外一个jar一样),这时可以选择将B打包入A中,或者将B也发布出去,等别人需要用A时,告诉开发者,想要用A就必须在导入Bjar包。但是两个都很麻烦,前者可能造成资源的浪费(比如,开发者可能正在开发依赖B的其它项目,B已经存储到本地了,在导入A的jar包的话,就有了两个B的jar),后者是我们常遇到的,找各种jar包,非常麻烦。
上面问题的描述,其实属于项目与项目之间依赖的问题[A项目使用SSH的所有jar,就说A项目依赖SSH],人为手动的去解决,很繁琐,也不方便,所以需要使用Maven来帮我们管理。
看了上面这个案例,我们知道了Maven的应用背景,那么回归到主题,Maven是什么?通俗点讲,Maven的核心功能便是合理叙述项目间的依赖关系,就是通过pom.xml文件的配置获取jar包,而不用手动去添加jar包,maven项目,就是在java项目和web项目的上面包裹了一层maven,本质上java项目还是java项目,web项目还是web项目,但是包裹了maven之后,就可以使用maven提供的一些功能了(通过pom.xml添加jar包)。
进一步细化探究,怎么通过pom.xml的配置就可以获取到jar包呢?pom.xml配置文件从何而来? 如果用pom.xml文件,那么该项目需要为Maven项目,怎么来创建Maven项目?
这时我们发现使用Maven,最终的目的就是学会如何创建maven项目,maven项目的结构是怎样,与普通java,web项目的区别在哪里,如何在pom.xml中配置获取到我们想要的jar包等等技术使用问题。
通过pom.xml中的配置,就能够获取到想要的jar包(还没讲解如何配置先需要了解一下仓库的概念),但是这些jar是在哪里呢?就是我们从哪里获取到的这些jar包?答案就是仓库。仓库分为:本地仓库、第三方仓库(私服)、中央仓库。
Maven会将工程中依赖的构件(Jar包)从远程下载到本机一个目录下管理,每个电脑默认的仓库是在 $user.home/.m2/repository下。如图:
例如我的就在:C:\Users\Administrator.m2\repository,一般我们会修改本地仓库位置,自己创建一个文件夹,在从网上下载一个拥有相对完整的所有jar包的结合,都丢到本地仓库中,然后每次写项目,直接从本地仓库里拿就行了。修改本地库位置:$MAVEN_HOME/conf/setting.xml文件中修改,如图:
D:\java\maven\repository:就是我们自己创建的本地仓库,将网上下载的所有jar包,都丢到该目录下,我们就可以直接通过maven的pom.xml文件直接拿。
第三方仓库,又称为内部中心仓库,也称为私服。私服一般是由公司自己设立的,只为本公司内部共享使用。它既可以作为公司内部构件协作和存档,也可作为公用类库镜像缓存,减少在外部访问和下载的频率。(使用私服为了减少对中央仓库的访问。私服可以使用的是局域网,中央仓库必须使用外网,也就是一般公司都会创建这种第三方仓库,保证项目开发时,项目所需用的jar都从该仓库中拿,每个人的版本就都一样。注意:连接私服,需要单独配置。如果没有配置私服,默认不使用
Maven内置了远程公用仓库:,这个公共仓库是由Maven自己维护,里面有大量的常用类库,并包含了世界上大部分流行的开源项目构件。目前是以java为主,工程依赖的jar包如果本地仓库没有,默认从中央仓库下载。
之前一直在使用pom.xml中找jar包最关键的三个属性,groupId、artifactId、version,如果你之前使用过Maven,对这个应该对这三个元素比较熟悉,也知道为什么通过这三个能找到对应的jar包,这一章节,就将依赖关系全面分析。
为了避免不知道说的哪些配置属性,看下面图就明白了,就是dependency下的属性配置,全部有9个,讲其中的7个。
groupId、artifactId、version是依赖的基本坐标,缺一不可,限于篇幅,本文不对每个元素详细介绍,具体可以百度,关于配置的介绍文章非常多。
这个就是maven解决传递依赖时jar包冲突问题的方法,按照两种原则,上面已经介绍了一种了,就是下面的第二原则。
第二原则:第一声明者优先原则。就是如果路径相同,maven 默认配置在前面的优先使用:
这样就是路径相同,那么如果A在前面,C在后面,则使用X(1.6),maven会先根据第一原则进行选择,第一原则不成,则按第二原则处理。返回搜狐,查看更多