Maven

Maven简介

Maven是什么

  • Maven的本质是一个项目管理工具,将项目开发和管理过程抽象成一个项目对象模型(POM)
  • POM (Project Object Model):项目对象模型

000

Maven的作用

  • 项目构建:提供标准的、跨平台的自动化项目构建方式
  • 依赖管理:方便快捷的管理项目依赖的资源(jar包),避免资源间的版本冲突问题
  • 统一开发结构:提供标准的、统一的项目结构

下载安装及配置

  • 下载安装

    安装包在Apache官网Maven界面点击download下载,下载后解压即可。

  • 配置

    在环境变量中添加 MAVEN_HOME,在Path中添加其bin目录即可。

Maven基础概念

仓库

  • 仓库:用于存储资源,包含各种jar包。
    • 本地仓库:自己电脑上的存储资源的仓库,连接远程仓库获取资源
    • 远程仓库:非本机电脑上的仓库,为本地仓库提供资源
      • 中央仓库:Maven团队维护,存储所有资源的仓库
      • 私服:部门、公司范围内存储资源的仓库,从中央仓库获取资源。私服有以下作用:
        • 保存既具有权的资源,包含购买或自主研发的jar包
          • 中央仓库的jar包都是开源的
        • 一定范围内的共享资源,仅对内部开放,不对外共享

坐标

  • 什么是坐标?
    • Maven用坐标描述仓库中资源的位置
  • Maven坐标的主要组成
    • groupld:定义当前Maven项目隶属组织名称(通常是域名反写,例如:org.mybatis)
    • artifactld:定义当前Maven项目名称(通常是模块名称,例如CRM、SMS)
    • version:定义当前项目版本号
    • packaging:定义该项目的打包方式。
  • Maven坐标的作用
    • 使用唯一标识,唯一性定位资源位置,通过该标识可以将资源的识别与下载工作交由机器完成

本地仓库配置

配置文件在 D:\Maven\apache-maven-3.8.5\conf\settings.xml 中。

  • 默认位置:

     <!-- localRepository
       | The path to the local repository maven will use to store artifacts.
       |
       | Default: ${user.home}/.m2/repository
      <localRepository>/path/to/local/repo</localRepository>
      -->
    
  • 自定义位置:在默认位置下一行添加

    <localRepository>D:\Maven_repository</localRepository>
    

远程仓库配置

  • 远程仓库配置:默认中央仓库是Apache的,太慢。

  • 镜像仓库配置:在 D:\Maven\apache-maven-3.8.5\conf\settings.xml 文件中配置阿里云镜像仓库。

    <mirrors>
        <mirror>
            <id>nexus-aliyun</id>
            <mirrorOf>central</mirrorOf>
            <name>Nexus aliyun</name>
            <url>http://maven.aliyun.com/nexus/content/groups/public</url>
        </mirror>
    </mirrors>
    

手撸Maven项目

Maven工程目录结构

012

<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/maven-v4_0_0.xsd">
   <modelVersion>4.0.0</modelVersion>

   <groupId>com.kiang</groupId>
   <artifactId>project-java</artifactId>
   <version>1.0</version>
   <packaging>jar</packaging>

   <dependencies>
      <dependency>
         <groupId>junit</groupId>
         <artifactId>junit</artifactId>
         <version>4.12</version>
      </dependency>

</project>

Maven项目构建命令

  • Maven构建命令使用mvn开头,后面添加功能参数,可以一次执行多个命令,使用空格分隔

    • mvn compile #编译
    • mvn clean #清理
    • mvn test #测试
    • mvn package #打包 mvn
    • install #安装到本地仓库
  • 插件创建工程

    • 创建工程

      mvn archetype:generate
          -DgroupId={project-packaging} 
          -DartifactId={project-name} 
          -DarchetypeArtifactId=maven-archetype-quickstart
          -DinteractiveMode=false
      
    • 创建java工程

      mvn archetype:generate -DgroupId=com.itheima -DartifactId=java-project -
      DarchetypeArtifactId=maven-archetype-quickstart -Dversion=0.0.1-snapshot -
      DinteractiveMode=false
      
    • 创建web工程

      mvn archetype:generate -DgroupId=com.itheima -DartifactId=web-project -
      DarchetypeArtifactId=maven-archetype-webapp -Dversion=0.0.1-snapshot -
      DinteractiveMode=false
      

IDEA生成Maven项目

创建按部就班,只是坑比较多

创建

  1. 新建模块

    013

  2. 注意选本地Mavenue那一套

    014

  3. 等他下好依赖即可

注意JDK版本需以下几个地方需一致,不然编译时嗷嗷报错。

  • 015
  • 016
  • 017
  • 018

关键是你设了还不行,如果你不写在配置文件里,它自己个还会变回去。

  • 临时解决:在项目pom.xml里写

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.encoding>UTF-8</maven.compiler.encoding>
        <java.version>14</java.version>
        <maven.compiler.source>14</maven.compiler.source>
        <maven.compiler.target>14</maven.compiler.target>
    </properties>
    
  • 永久解决:在Maven的setting里写

    <profile>
        <id>jdk14</id>
        <activation>
            <activeByDefault>true</activeByDefault>
            <jdk>14</jdk>
        </activation>
        <properties>
            <maven.compiler.source>14</maven.compiler.source>
            <maven.compiler.target>14</maven.compiler.target>
            <maven.compiler.compilerVersion>14</maven.compiler.compilerVersion>
            <maven.compiler.encoding>UTF-8</maven.compiler.encoding>
        </properties>
    </profile>
    
  • 其他设置最好在全局里设好:

    019

依赖管理

依赖配置

  • 依赖指当前项目运行所需要的jar

  • 格式

    <!--  设置当前项目运行所依赖的全部jar-->
    <dependencies>
        <!--    设置具体依赖-->
        <dependency>
            <!--      依赖所属的群体id-->
            <groupId>junit</groupId>
            <!--      依赖所属项目id-->
            <artifactId>junit</artifactId>
            <!--      依赖版本号-->
            <version>4.11</version>
        </dependency>
    </dependencies>
    

依赖传递

依赖具有传递性

  • 直接依赖:在当前项目中通过依赖配置建立的依赖关系

  • 间接依赖:被资源的资源如果依赖其他资源,当前项目间接依赖其他资源

依赖传递冲突问题
  • 路径优先:当依赖中出现相同的资源时,层级越深,优先级越低,层级越浅,优先级越高
  • 声明优先:当资源在相同层级被依赖时,配置顺序靠前的覆盖配置顺序靠后的
  • 特殊优先:当同级配置了相同资源的不同版本,后配置的覆盖先配置的

020

可选依赖

可选依赖指对外隐藏当前所依赖的资源(不透明)

<dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.11</version>
    <optional>true</optional>
</dependency>

排除依赖

排除依赖指主动断开依赖的资源,被排除的资源无需指定版本

<dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.11</version>
    <exclusions>
        <execlusion>
            <groupId>org.hamcrest</groupId>
            <artifactId>hamcrest-core</artifactId>
        </execlusion>
    </exclusions>
</dependency>

依赖范围

依赖的jar默认情况可以在任何地方使用,可以通过scope标签设定其作用范围

作用范围:

  • 主程序范围有效(main文件夹范围内)
  • 测试程序范围有效(test文件夹范围内)
  • 是否参与打包(package指令范围内)
scope 主代码 测试代码 打包 范例
compile(默认) \(\checkmark\) \(\checkmark\) \(\checkmark\) log4j
test \(\times\) \(\checkmark\) \(\times\) junit
provided \(\checkmark\) \(\checkmark\) \(\times\) servlet-api
runtime \(\times\) \(\times\) \(\checkmark\) jdbc
依赖范围传递性

带有依赖范围的资源在进行传递时,作用范围将受到影响。

间接依赖\(\downarrow\) 直接依赖\(\rightarrow\) complie test provided runtime
complie complie test provided runtime
test
provided
runtime test provided runtime

生命周期与插件

项目构建生命周期

Maven构建生命周期描述的是一次构建过程经历了多少事件。

021

Maven对项目构建的生命周期划分为3套

  • clean:清理工作
    • pre-clean:执行一些需要在clean之前完成的工作
    • clean:移除所有上一次构建生成的文件
    • post-clean:执行一些需要在clean之后立刻完成的工作
  • default:核心工作,例如编译,测试,打包,部署等
    • validate(校验):校验项目是否正确并且所有必要的信息可以完成项目的构建过程。
    • initialize(初始化):初始化构建状态,比如设置属性值。
    • generate-sources(生成源代码):生成包含在编译阶段中的任何源代码
    • process-sources(处理源代码):处理源代码,比如说,过滤任意值。
    • generate-resources(生成资源文件):生成将会包含在项目包中的资源文件。
    • process-resources(处理资源文件):复制和处理资源到目标目录,为打包阶段最好准备。
    • compile(编译):编译项目的源代码。
    • process-classes(处理类文件):处理编译生成的文件,比如说对Java class文件做字节码改善优化。
    • generate-test-sources(生成测试源代码):生成包含在编译阶段中的任何测试源代码。
    • process-test-sources(处理测试源代码):处理测试源代码,比如说,过滤任意值。
    • generate-test-resources(生成测试资源文件):为测试创建资源文件。
    • process-test-resources(处理测试资源文件):复制和处理测试资源到目标目录。
    • test-compile(编泽测试源码):编译测试源代码到测试目标目录。
    • process-test-classes(处理测试类文件):处理测试源码编译生成的文件。
    • test(测试):使用合适的单元测试框架运行测试(Juint是其中之一)。
    • prepare-package(准备打包):在实际打包之前,执行任何的必要的操作为打包做准备。
    • package(打包):将编译后的代码打包成可分发格式的文件,比如JAR、WAR或者EAR文件。
    • pre-integration-test(集成测试前):在执行集成测试前进行必要的动作,比如说,搭建需要的环境
    • integration-test(集成测试):处理和部署项目到可以运行集成测试环境中。
    • post-integration-test(集成测试后):在执行集成测试完成后进行必要的动作。比如说,清理集成测试环境。
    • verify(验证):运行任意的检查来验证项目包有效目达到质量标准。
    • install(安装):安装项目包到本地仓库,这样项目包可以用作其他本地项目的依赖。
    • deploy(部署):将最终的项目包复制到远程仓库中与其他开发者和项目共享。
  • site:产生报告,发布站点等
    • pre-site:执行一些需要在生成站点文档之前完成的工作
    • site:生成项目的站点文档
    • post-site:执行一些需要在生成站点文档之后完成的工作,并且为部署做准备
    • site-deploy:将生成的站点文档部署到特定的服务器上

插件

  • 插件与生命周期内的阶段绑定,在执行到对应生命周期时执行对应的插件功能
  • 默认maven在各个生命周期上绑定有预设的功能
  • 通过插件可以自定义其他功能
  • 插件与生命周期内的阶段绑定,在执行到对应生命周期时执行对应的插件功能
  • 默认maven在各个生命周期上绑定有预设的功能
  • 通过插件可以自定义其他功能

Maven高级

分模块开发与设计

022

未完待续,以后再学….

聚合

未完待续,以后再学….

继承

未完待续,以后再学….

属性

未完待续,以后再学….

版本管理

未完待续,以后再学….

资源配置

未完待续,以后再学….

多环境开发配置

未完待续,以后再学….

跳过测试

未完待续,以后再学….

私服

未完待续,以后再学….

原文地址:http://www.cnblogs.com/AncilunKiang/p/16817466.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性