maven是一个项目管理工具,使用maven对Java项目进行构建和依赖管理。


1、传统与maven对比

1.1 项目构建

  • 传统 : 要对工程中的源代码进行编译,及把Java文件编译成class文件。执行测试,打成war包部署Tomcat。
  • maven : 把将项目的每一个阶段进行了标准化。项目在编码完成后,对项目进行编译、测试、打包、部署等一系列的操作都通过命令来实现
  • 好处: 命令完成构建、编译、打包,方便快捷;方便团队多人进行开发。

1.2 依赖管理

  • 传统:需要人工进行导包,容易造成包冲突,而且会导致项目会很大。
  • maven 依赖管理:只需要在pom.xml中添加jar包的坐标即可,而且maven会自动卸载jar包。
  • 好处:maven管理jar包,避免了版本冲突;自动下载jar包。

1.3 总评maven

  • 对项目标准化,一步构建。
  • 依赖管理,自动下载jar包。
  • 跨平台,Linux可用。
  • maven构建项目,降低了项目的维护成本。

2、 maven介绍

2.1 下载安装

  • 前提:maven程序java开发,它的运行依赖jdk。所以要先安装配置JDK
  • 下载官网:http://maven.apache.org/download.cgi
  • 配置:
    - 配置 MAVEN_HOME —> D:\apache-maven-3.5.0(路径)
    - path环境变量%MAVEN_HOME%/bin ----> path
  • 检查是否安装成功:mvn -v ---->看是否出现maven版本号与jdk版本

2.2 目录介绍

  • bin 可执行的脚本命令,mvn.bat(以run运行项目)、mvnDebug.bat(以debug方式运行项目)
  • boot maven运行需要的类加载器
  • conf 配置文件中心
  • lib maven运行依赖jar包

2.3 maven仓库

  • 本地仓库:在我们计算机上存jar包的地方,当你需要某个jar包时回去远程仓库或者中央仓库下载,并存在这里。默认在Windows用户下的.m2/repository
  • 远程仓库: 可以是互联网或者是局域网内。
  • 中央仓库:即jar中部,http://repo1.maven.org/maven2

2.4 配置本地仓库

  • 目的:让maven程序知道仓库在哪
  • 配置:在conf/setting.xml
    <localRepository>本地仓库路径</localRepository>

2.5 maven的常用命令

  • clean : 清理 —> 将项目根目录下target目录清理掉。
  • compile : 编译 —> 将项目中.java文件编译为.class文件
  • test : 单元测试 —> 单元测试类名有要求:XxxxTest.java
    将项目根目录下src/test/java目录下的单元测试类都会执行。
  • package : 打包
    web project ---- war包
    java project -----jar包
    —> 将项目打包,打包项目根目录下taget目录
  • install : 安装 —> 解决本地多个项目公用一个jar包。打包到本地仓库

2.6 maven项目工程目录

工程根目录下就只有src和target两个目录

  • src
    - main
    –bin 脚本库
    –java java源代码文件
    –resources 资源库,会自动复制到classes目录里
    –filters 资源过滤文件
    –assembly 组件的描述配置(如何打包)
    –config 配置文件
    –webapp web应用的目录。WEB-INF、css、js等
    - test
    –java 单元测试java源代码文件
    –resources 测试需要用的资源库
    –filters 测试资源过滤库
  • target
    target是有存放项目构建后的文件和目录,jar包、war包、编译的class文件等。target里的所有内容都是maven构建的时候生成的

2.7 maven生命周期

Maven拥有三套相互独立的生命周期,它们分别为clean,default和site。 每个生命周期包含一些阶段,这些阶段是有顺序的,并且后面的阶段依赖于前面的阶段,用户和Maven最直接的交互方式就是调用这些生命周期阶段。

以clean生命周期为例,它包含的阶段有pre-clean, clean 和 post clean。当用户调用pre-clean的时候,只有pre-clean得以执行,当用户调用clean的时候,pre-clean和clean阶段会得以顺序执行;当用户调用post-clean的时候,pre-clean,clean,post-clean会得以顺序执行。

较之于生命周期阶段的前后依赖关系,三套生命周期本身是相互独立的,用户可以仅仅调用clean生命周期的某个阶段,或者仅仅调用default生命周期的某个阶段,而不会对其他生命周期产生任何影响。

  • clean 生命周期
    - clean生命周期的目的是清理项目,它包含三个阶段:
    1)pre-clean 执行一些清理前需要完成的工作。
    2)clean 清理上一次构建生成的文件。
    3)post-clean 执行一些清理后需要完成的工作。
  • default 生命周期
    - default生命周期定义了真正构件时所需要执行的所有步骤,它是生命周期中最核心的部分,它包含的阶段如下:
    1) validate 验证项目是否正确和所有需要的相关资源是否可用
    2) initialize 初始化构建
    3) generate-sources
    4) process-sources 处理源代码
    5) generate-resources
    6) process-resources 处理项目主资源文件。对src/main/resources目录的内容进行变量替换等工作后,复制到项目输出的主classpath目录中。
    7) compile 编译项目的主源代码
    8) process-classes
    9) generate-test-sources
    10) process-test-sources 处理项目测试资源文件
    11)generate-test-resources
    12) process-test-resources 处理测试的资源文件
    13)test-compile 编译项目的测试代码
    14)process-test-classes
    15) test 使用单元测试框架运行测试,测试代码不会被打包或部署
    16)prepare-package 做好打包的准备
    17)package 接受编译好的代码,打包成可发布的格式
    18) pre-integration-test
    19) integration-test
    20) post integration-test
    21) verify
    22) install 将包安装到Maven本地仓库,供本地其他Maven项目使用
    23)deploy 将最终的包复制到远程仓库,供其他开发人员和Maven项目使用
  • site 生命周期
    site生命周期的目的是建立和发布项目站点,Maven能够基于POM所包含的信息,自动生成一个友好的站点,方便团队交流和发布项目信息。该生命周期包含如下阶段:
    1)pre-site 执行一些在生成项目站点之前需要完成的工作
    2)site 生成项目站点文档
    3)post-site 执行一些在生成项目站点之后需要完成的工作
    4)site-deploy 将生成的项目站点发布到服务器上