继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

重塑内功-工具系列-Maven到底是个啥玩意

大叔也是小清新
关注TA
已关注
手记 2
粉丝 8
获赞 36
Maven,是基于项目对象模型(POM),可以通过一小段描述信息来管理项目的构建,报告和文档的软件项目管理工具。
       上面是百度百科对Maven的正式介绍,如果你是Maven初学者,我估计你看完之后心中肯定会有一万头姓草的动物奔腾而过,严重者甚至对Maven留下心理阴影。好吧,Maven到底是什么玩意?
一、场景问题
       解释之前,提1个小问题:
       假如你正在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是什么?通俗点讲,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内置了远程公用仓库:http://repo1.maven.org/maven2,这个公共仓库是由Maven自己维护,里面有大量的常用类库,并包含了世界上大部分流行的开源项目构件。目前是以java为主,工程依赖的jar包如果本地仓库没有,默认从中央仓库下载。
(四)小结
       获取jar包的过程:

图片描述
三、pom.xml的依赖关系讲解
       之前一直在使用pom.xml中找jar包最关键的三个属性,groupId、artifactId、version,如果你之前使用过Maven,对这个应该对这三个元素比较熟悉,也知道为什么通过这三个能找到对应的jar包,这一章节,就将依赖关系全面分析。
(一)如何获取坐标(也就是三个关键属性值)
       方式1:使用网站搜索[从中央仓库拿]。
           步骤1:百度搜索关键字“maven repository”。

图片描述
           步骤二:输入关键字查询获得需要内容,确定需要版本。
图片描述
           步骤三:获得坐标。
图片描述
       方式2:使用本地仓库,通过myeclipse获得坐标。
       上面已经介绍过了如何从本地仓库获取对应jar,这里在简单阐述一下:
           步骤一:添加依赖,pom.xml文件中,右键:
图片描述
           步骤二:获得坐标。
图片描述
(二)依赖(坐标)的常见配置
       为了避免不知道说的哪些配置属性,看下面图就明白了,就是dependency下的属性配置,全部有9个,讲其中的7个。
图片描述
       groupId、artifactId、version是依赖的基本坐标,缺一不可,限于篇幅,本文不对每个元素详细介绍,具体可以百度,关于配置的介绍文章非常多。
(二)依赖调节原则
       这个就是maven解决传递依赖时jar包冲突问题的方法,按照两种原则,上面已经介绍了一种了,就是下面的第二原则。
       第一原则:路径近者优先原则:
           A–>B–>C–>D–>X(1.6) 
           E–>D–>X(2.0)
           使用X(2.0),因为其路径更近
       第二原则:第一声明者优先原则。就是如果路径相同,maven 默认配置在前面的优先使用:
           A–>B --> X(1.6)
           C–>D–> X(2.0)
           这样就是路径相同,那么如果A在前面,C在后面,则使用X(1.6),maven会先根据第一原则进行选择,第一原则不成,则按第二原则处理。

打开App,阅读手记
2人推荐
发表评论
随时随地看视频慕课网APP

热门评论

谢谢,大概理解了。就是说maven的存在意义就像是一个仓库,需要什么从里面引入或者拿取就行,而不必关心仓库是怎么拿到的,仓库建好后大家共同维护就行。

查看全部评论