Maven核心知识

1.maven常用的构建命令

(1)mvn -v      查看maven版本

(2)compile    编译

(3)test        测试

(4)package      打包

(5)clean     删除target

(6)install       安装jar包到本地仓库中

2.maven自动建立目录骨架

(1)archetype插件

  • 用于创建符合maven规定的目录骨架
  • 先创建一个文件夹,其名为project名

(2)自动创建目录方式一

  • win+R,cmd,cd到该文件夹路径下,输入mvn archetype:generate,enter,第一次会自动下载一些相关依赖
  • enter,输入6
    • 'groupId' 输入com.gc.maven;
    • 'artifactId'输入maven-service;
    • 'version'输入1.0.0SNAPSHOT;
    • 'package'输入com.gc.maven.service,
    • enter,输入y
  • 至此自动创建成功
  • 这是按照提示进行选择的方法

(3)自动创建目录方式二

  • win+R,cmd,cd到该文件夹路径下
  • 输入mvn archetype:generate -DgroupId=组织名,公司网址的反写+项目名 -DartifactId=项目名-模块名 -Dversion=版本号 -Dpackage=代码所存在的包名

3.maven中的坐标和仓库

(1)坐标

  • 构件通过坐标作为其唯一标识
  • groupId,artifactId,version组成项目的基本坐标

(2)仓库

  • 仓库管理项目的依赖
  • 本地仓库和远程仓库:打开maven—>lib—>maven-model-builder-3.5.4.jar,用360压缩打开,org—>apache—>maven—>model—>pom-4.0.0.xml,打开,找到<url>https://repo.maven.apache.org/maven2</url>,即为远程仓库
  • 镜像仓库:打开maven—>conf—>settings.xml,找到mirrors,配置1-2个镜像     
   <mirror>
      <id>jboss-public-repository-group</id>
      <mirrorOf>central</mirrorOf>
      <name>JBoss Public Repository Group</name>
      <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
   </mirror>
   <mirror>
      <id>alimaven</id>
      <mirrorOf>central</mirrorOf>
      <name>aliyun maven</name>
      <url>http://maven.aliyun.com/nexus/content/repositories/central/</url>
   </mirror>
  • 更改仓库位置:默认本地仓库在c盘中C:\Users\guochan\.m2,如果重装系统可能丢失,所以要更改仓库位置 
    • 创建一个本地文件夹其路径为E:\maven\repo,打开maven—>conf—>settings.xml,找到localRepository,
    • <localRepository>E:/maven-3.5.0/repository</localRepository>
    • win+R cmd ,输入命令mvn compile测试是否成功

4.在Intellij IDEA中配置maven以及创建maven项目

(1)配置maven

  • Ctrl+Shift+A,输入maven,选择maven settings
  • 在maven home directory中选择maven文件夹目录,我这里是D:/Program Files (x86)/apache-maven-3.5.4-bin/apache-maven-3.5.4
  • 在user setting file中选择override,填入修改好本地仓库位置的配置文件,我这里是D:\Program Files (x86)\apache-maven-3.5.4-bin\apache-maven-3.5.4\conf\settings.xml
  • local repository会自动检测到修改过的本地仓库路径
  • 在settings搜索框中输入runner,找到maven下的runner,在VM Options中输入-DarchetypeCatalog=internal,如果未配置会导致maven 骨架生成速度缓慢
  • 配置完成
  • File—>other settings—>default settings,再将刚才配置一遍,在创建maven项目的时候就不用重复配置了

(2)创建maven web项目

  • File—>New—>Project,选择maven,在create from archetype打勾,选择,next
  • 输入groupId和artifactId,next
  • 仍然选择maven home directory为D:/Program Files (x86)/apache-maven-3.5.4-bin/apache-maven-3.5.4
  • user setting file选择override,为D:\Program Files (x86)\apache-maven-3.5.4-bin\apache-maven-3.5.4\conf\settings.xml
  • local repository会自动检测到修改过的本地仓库路径
  • 上述加下划线的三步如果在default settings中配置过即可忽略
  • 点绿色的+,Name中输入archetypeCatalog,Value中输入internal,OK(该属性设置可以加快项目创建速度),next,finish
  • 如果创建maven项目失败,错误[ERROR] Maven execution terminated abnormally (exit code 1)
    • 原因:如果path里有两个java环境,则会导致创建失败
    • 解决办法:查看Path路径下发现有C:\ProgramData\Oracle\Java\javapath和%JAVA_HOME%\bin这两个java环境,删除C:\ProgramData\Oracle\Java\javapath即可正常创建
  • 创建好的项目结构缺少一些文件夹,手动补全,Alt+Insert,按照上一篇的目录结构添加directory,在main下添加java和resources,在src下添加test和resources
  • Ctrl+;调出Project Structure,点击Modules,main下的java选择Sources,main下resources选择Resources;test下的java选择Tests,test下的resources选择Test Resources

5.maven的生命周期和插件

(1)完整项目的构建过程

  • 清理、编译、测试、打包、集成测试、验证、部署

(2)maven生命周期

  • clean  清理项目
    • pre-clean              执行清理前的工作
    • clean                    清理上一次构建生成的所有文件
    • post-clean            执行清理后的文件
  • default   构建项目(最核心)
    • compile
    • test
    • package
    • install
  • site   生成项目站点
    • pre-site           在生成项目站点前要完成的工作
    • site                      生成项目的站点文档
    • post-site              在生成项目站点后要完成的工作
    • site-deploy          发布生成的站点到服务器上

(3)maven的插件

  • 详细插件信息可查看http://maven.apache.org/plugins/index
  • 下面以使用source插件为例,希望运行package时即可将源码打包,在pom.xml中写入
<build>
    <plugins>
      <plugin>
        <artifactId>maven-source-plugin</artifactId>
        <version>2.4.0</version>
        <executions>
          <execution>
            <phase>package</phase>
            <goals>jar-no-fork</goals>
          </execution>
        </executions>
      </plugin>
    </plugins>
  </build>
  • 其中goals可以从上述网站中查看

6.maven中pom.xml解析

<?xml version="1.0" encoding="UTF-8"?>


<!--project是pom.xml的根元素,包含pom约束的信息-->
<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">
  <!--指定当前pom的版本,也是必不可少的元素-->
  <modelVersion>4.0.0</modelVersion>


  <groupId>反写的公司网址+项目名</groupId>
  <artifactId>项目名+模块名</artifactId>
  <!--第一个0表示大版本号
      第二个0表示分支版本号
      第三个0表示小版本号
      0.0.1
      snapshot   快照
      alpha      内部测试
      beta       公测
      Release    稳定
      GA         正式发布
  -->
  <version>1.0-SNAPSHOT</version>
  <!--jar war zip pom-->
  <packaging>war</packaging>


  <name>项目描述名</name>
  <url>项目地址</url>
  <description>项目描述</description>
  <developers>开发人员列表</developers>
  <licenses>开源框架许可证信息</licenses>
  <organization>组织信息</organization>


  <!--依赖列表-->
  <dependencies>
    <!--依赖项-->
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <type></type>
      <!--依赖范围 test表示junit只在测试的依赖范围内有用,在main主代码中引用junit会报错-->
      <scope>test</scope>
      <!--设置依赖是否可选,有true和false,默认是false,子项目继承,若为true,子项目必须显示引入该依赖-->
      <optional>false</optional>
      <!--排除依赖传递列表-->
      <exclusions>
        <exclusion>
        </exclusion>
      </exclusions>
    </dependency>
  </dependencies>


  <!--依赖的管理,主要定义在父模块中,供子模块继承-->
  <dependencyManagement>
    <!--依赖列表-->
    <dependencies>
      <!--多个依赖,但这些依赖并不会被运行,不会被引入实际的依赖中-->
      <dependency>
      </dependency>
    </dependencies>
  </dependencyManagement>


  <!--对构件行为提供相应的支持-->
  <build>
    <!--插件列表-->
    <plugins>
      <plugin>
        <groupId></groupId>
        <artifactId></artifactId>
        <version></version>
      </plugin>
    </plugins>
    <!--通常用于子模块对父模块pom的继承-->
    <parent></parent>
    <!--用来聚合运行多个maven项目,使很多maven模块一起编译-->
    <modules>
      <module></module>
    </modules>
  </build>
</project>

7.maven依赖范围

(1)<scope>

  • maven的依赖范围
  • 开发时使用某一框架,将该项目的jar包引入到项目的classpath路径中,项目即可使用该框架为我们封装好的一些方法
  • 依赖范围就是控制依赖与classpath的关系

(2)maven中的classpath

  • 编译 
  • 测试:例如junit依赖范围中的值test表明junit只存在于测试的classpath中
  • 运行

(3)scope的值

  • 打开http://maven.apache.org/,点击右侧栏中的Documentation-Index(category),点开Introductions-The Dependency Mechanism(依赖机制),找到Dependency Scope
  • 有6种scope的值,介绍如下
    • compile:默认的范围,在编译、测试、运行时都有效。
    • provided:在编译、测试时有效。例子:Servlet API加载,运行时不会被加入,因为web容器已经包含了这些API,如果加入进去会导致冲突。
    • runtime:在测试、运行时有效。例子:jdbc驱动的实现,项目主代码的编译只需要JDK提供的jdbc的API,只有在执行测试和运行项目的时候才需要实现接口的具体的jdbc驱动。
    • test:只在测试时有效。例子:junit。
    • system:与provided相同,在编译,测试时有效,与本机系统相关联,可移植性差,换机子以后可能会出问题。比如我们要引用本机的JAVA_HOME,如果把项目移植到其他系统上,可能由于路径的不一致而导致错误。
    • import:导入的依赖范围,它只使用在dependencyManagement中,表示从其他的pom中导入dependency配置(是从其他pom中继承的依赖)。

8.maven依赖传递

(1)依赖传递的例子

  • 假设A依赖于B,B依赖于C
  • 首先在B的pom.xml中添加B对C的依赖
<dependency>
    <groupId>com.gc.C</groupId>
    <artifactId>C</artifactId>
    <version>1.0-SNAPSHOT</version>
</dependency>
  • 再在A的pom.xml中添加A对B的依赖
<dependency>
    <groupId>com.gc.B</groupId>
    <artifactId>B</artifactId>
    <version>1.0-SNAPSHOT</version>
</dependency>
  • 然后对C clean package(生成C的jar包) install(C的jar包安装到本地仓库中);再对B clean package(生成B的jar包) install(B的jar包安装到本地仓库中)
  • 对A clean compile,即会发现在A的Maven Dependencies中有B.jar和C.jar。在A的pom.xml中并没有配置C,所以这就是传递依赖

(2)排除依赖

  • 若A只想依赖于B,不想依赖于C,则可在A的pom.xml中加入exclusion,这样A中Maven Dependencies就自动去除了C.jar
<dependency>
      <groupId>com.gc.B</groupId>
      <artifactId>B</artifactId>
      <version>1.0-SNAPSHOT</version>
      <exclusions>
            <exclusion>
                <groupId>com.gc.C</groupId>
                <artifactId>C</artifactId>
             </exclusion>
       </exclusions>
</dependency>

9.maven依赖冲突

(1)产生依赖冲突的场景

  • A和B依赖了不同版本的相同的构件,那么对依赖A、B的C来说依赖的是哪个版本的构件,这就产生了依赖冲突

(2)两条原则

  • 短路优先
    • A—>B—>C—>X(jar)
    • A—>D—>X(jar),选择此依赖
  • 先声明先优先
    • 如果路径长度相同,则谁先声明,先解析谁

10.maven聚合和继承

(1)使用聚合的场景:

  • maven中将多个项目install,将其安装到本地仓库中,聚合可以将他们放到一起运行,称为聚合

(2)聚合的例子:

  • 想要将项目A,B,C一起install到本地仓库中
  • 新建一个新的maven项目D,其pom.xml如下
    <packaging>pom</packaging>
    
      <modules>
       <module>../A</module>
       <module>../B</module>
       <module>../C</module>
      </modules>
  • 对D的pom.xml clean install,即可将A,B,C生产jar包并安装到本地仓库中
  • D的pom.xml作为其他项目pom的容器

(3)使用继承的场景:

  • 很多项目的pom.xml中有很多重复的配置,例如junit等,可以利用继承减少配置

(4)继承的例子:

  • 假设有parent项目和sub项目,则分别配置parent和sub的pom.xml
  • 新建一个新的maven项目parent,其pom.xml如下
<packaging>pom</packaging>

<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<junit.version>4.11</junit.version>
</properties>

<dependencyManagement>
  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>${junit.version}</version>
      <scope>test</scope>
    </dependency>
  </dependencies>
</dependencyManagement>
  • 在sub项目中的pom.xml修改如下(将junit中的version和scope删除):
    <parent>
      <groupId>com.gc.parent</groupId>
      <artifactId>parent</artifactId>
      <version>1.0-SNAPSHOT</version>
    </parent>

    <dependencies>
      <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
      </dependency>
    </dependencies>
  • 此时junit就可以从parent的pom中继承过来

猜你喜欢

转载自www.cnblogs.com/chanaichao/p/9259154.html