一.前言java
之前作过的项目中,没有真正的使用过Maven,只知道其名声很大,其做用是用来管理jar 包的。最近一段时间在项目过程当中使用Maven,用Maven构建的web项目,其项目结构只停留在了解阶段,没有深刻的使用与理解,恰好最近看了一篇关于Maven的详解;就开始深刻学习一下Maven的具体应用。web
二.Maven的做用apache
下面咱们来对比一下,首先创建一个普通的Java工程,是这样的:windows
这个咱们都很熟悉,src下建包写代码,那么配置文件放在哪里?单元测试代码放在哪里?没有一个统一标准,更多时候都是开发者的自由发挥,每一个人有本身的风格,这并不十分适合团队协做。接下来,看一下使用maven构建一个普通Java项目以后的目录结构:mybatis
看到使用Maven构建的普通Java项目,对源代码、单元测试代码、资源乃至后续须要的文件都有专门的目录规划。app
上面的最后有一个pom.xml,这是Maven的核心配置文件,pom称为Project Object Model(项目对象模型),它用于描述整个Maven项目,因此也称为Maven描述文件。webapp
固然事情不会这么简单,接下来,继续进入Maven的世界吧。maven
pom.xml工具
打开pom.xml,最基础的是这样的:单元测试
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.xrq.withmaven</groupId> <artifactId>withmaven</artifactId> <version>0.0.1-SNAPSHOT</version> <build/> </project>
一、modelVersion由于这个配置文件是Maven的核心,所以有必要详细解读一下pom.xml,来先看一下上面的几个:
指定了当前Maven模型的版本号,对于Maven2和Maven3来讲,它只能是4.0.0
二、groupId
顾名思义,这个应该是公司名或是组织名。通常来讲groupId是由三个部分组成,每一个部分之间以"."分隔,第一部分是项目用途,好比用于商业的就是"com",用于非营利性组织的就 是"org";第二部分是公司名,好比"tengxun"、"baidu"、"alibaba";第三部分是你的项目名
三、artifactId
能够认为是Maven构建的项目名,好比你的项目中有子项目,就可使用"项目名-子项目名"的命名方式
四、version
版本号,SNAPSHOT意为快照,说明该项目还在开发中,是不稳定的版本。在Maven中很重要的一点是,groupId、artifactId、version三个元素生成了一个Maven项目的基本坐标,这很是重要,我在使用和研究Maven的时候屡次感觉到了这点。
在上面的这些元素以外,还有一些元素,一样罗列一下:
一、packing
项目打包的类型,可使jar、war、rar、ear、pom,默认是jar
二、dependencies和dependency
前者包含后者。前面说了,Maven的一个重要做用就是统一管理jar包,为了一个项目能够build或运行,项目中不可避免的,会依赖不少其余的jar包,在Maven中,这些依赖就被称为dependency。
说到这里,就有一个本地仓库和远程仓库的概念了。官方下载的本地仓库的配置在"%MAVEN_HOME%\conf\settings.xml"里面,找一下"localRepository"就能够了;MyEclipse默认的本地仓库的地址在"{user.home}/.m2/repository"路径下,一样找一下"localRepository"就能够找到MyEclipse默认的本地仓库了。
本地仓库和远程仓库是这样的,Maven工程首先会从本地仓库中获取jar包,当没法获取指定jar包时,本地仓库会从远程仓库(中央仓库)中下载jar包,并放入本地仓库以备未来使用。
举个例子,比方说个人项目中用到了MyBatis,那么能够这么配置:
<dependencies> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.2.5</version> </dependency> </dependencies>
以前有说过groupId、artifactId、version惟一标识一个Maven项目,有了这三个元素,咱们就能够去远程仓库下载MyBatis3.2.5.jar到本地仓库了。回想咱们以前的作法,若是要MyBatis的jar包,发现没有,而后去网上下载一个,须要另外的jar包,而后去网上下载一个,可是有了Maven,就方便多了,只须要配置jar包对应的dependency依赖,Maven会自动帮助咱们去远程仓库中下载jar包到本地仓库中。
三、properties
properties是用来定义一些配置属性的,例如project.build.sourceEncoding(项目构建源码编码方式),能够设置为UTF-8,防止中文乱码,也可定义相关构建版本号,便于往后统一升级。
四、build
build表示与构建相关的配置,好比build下有finalName,表示的就是最终构建以后的名称。
接着解释一下Maven的目录结构:
三.Maven环境配置
经常使用的开发工具Idea、MyEclipse里面都已经集成了Maven了,不过最好是从官网下一个配置到本身电脑里,开发工具里的可能有少量的Bug。
首先去Maven官网,下载Maven的包,地址为http://maven.apache.org/download.cgi,找到下面的部分,点击就能够下载了:
下载完解压,而后配置一下环境变量,和JDK的环境变量配置相似:
这样配置完就能够了,验证一下,windows+r打开命令窗口,输入"mvn --version",若是有下面的内容这表示Maven配置OK:
Maven入门使用常见问题
一、我从SVN上下载了一个以Maven构建的工程,下载完毕没有jar包怎么办?
从资源库上下载下来的Maven工程,是没有jar包的,此时能够这么作:
(1)删除Maven工程,可是删除的时候不要删除本地工程里面的Maven工程,只删除MyEclipse中的Maven工程
(2)右键Import->Maven4MyEclipse->Existing Maven Projects,导入你的Maven工程,此时MyEclipse在构建工程的时候,假如你的本地仓库中没有dependcy中的jar包,便会去远程仓库下载jar包到本地仓库中。你的工程导入完毕以后,Library应该是这样的:
二、从新下载Maven工程所依赖的jar包、导入jar包都须要触发Maven工程的build workspace,那么如何才能触发Maven工程的build workspace?
找到一个pom.xml,随便修改一下,加一个空格、减一个空格什么的,ctrl+s保存一下,便会触发Maven工程的build workspace了
三、本地仓库的目录结构是什么样子的?
groupId、artifactId、version肯定一个惟一的Maven,比方说我有一个mybatis的dependcy:
<dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.2.5</version> </dependency>
四、有些jar包在dependcy里面有配置,Import了Maven工程,下载完工程所依赖的jar包以后,发现本地仓库里面却没有,怎么办?那么mybatis的jar包应该在%Maven仓库地址%\org\mybatis\mybatis\3.2.5\这一路径下,看到了吧,先groupId,再mybatis,最后version,每一个名字都是一个文件夹的名字
多是原先下载jar包的时候出了什么问题,从artifactId目录开始删除如下的全部文件/文件夹,而后触发一次Maven工程的build workspace就能够了
五、本地仓库中肯定已经有jar包了,工程里面却报错,说找不到jar包,该怎么办?
应该有不少解决办法,目前解决的一种办法是,MyEclipse->Window->Preferences->搜索Maven->User Settings,Update Settings和Reindex点一下就行了。另外,能够尝试一下把本地Maven仓库内的jar包删除一下,而后从新build workspace,可能也能够。