Maven
- 能够说出Maven的作用
- 能够安装Maven
- 能够使用Maven命令对项目进行清理、编译、测试、打包、安装的操作
- 能够使用Maven坐标导入jar包
- 能够说出依赖范围的作用
咱们回顾一下 JDBC 以及数据库连接池的使用,在学习 JDBC 的时候我们需要先引入对应数据库的驱动程序包,使用数据库连接池时需要导入 Druid 的 jar 包。在实际工作中,不是所有的内容都需要我们自己来开发实现,如果有成熟开源的实现,我们完全可以导入 jar 包直接使用。但随之而来就出现了一个问题,如果我们需要引入的 jar 包很多怎么办?当前我们只使用了两个,如果是几十、甚至上百个呢。
这个时候就需要有专门的工具来管理我们要用的 jar 包,它就是我们接下来要学习的 maven。
Maven
是专用用于管理和构建 Java 项目的工具,它的主要功能有:
- 提供一套标准化的项目结构
- 提供一套标准化的构建流程 (编译、测试、打包、发布 ......)
- 提供了一套依赖管理机制
下面我们先简单介绍一下 maven 的功能,后面再详细讲解。
- 标准化的项目结构:
项目结构就是我们的项目目录结构,每一个开发工具(IDE)都有自己不同的项目结构,它们互相之间不通用。在 Eclipse 中创建的目录结构,无法在 Idea 中进行使用,这就造成了很大的不方便,如图:
通过 Maven 创建的项目结构就可以避免 IDE 不通用的问题,如下图是 Maven 构建的项目结构。
- 标准化的构建流程:
如上图所示,我们开发一套系统,代码需要进行编译、测试、打包、发布等这些操作,如果这些操作需要反复进行就显得特别麻烦,Maven 就提供了一套简单的命令来完成项目构建。
- 依赖管理:
依赖管理就是管理项目所依赖的第三方资源,如:jar 包、插件等。就像之前我们项目中需要使用 JDBC 和 Druid,就需要去王桑下载对应的依赖包,复制到项目中,还要将 jar 包加入工作环境:
使用 Maven 就可以避免上面那么负责的操作,只需要使用 Maven 标准的坐标配置来管理各种依赖即可,只需要简单的配置就可以完成依赖管理。
如上图右边所示就是 MySQL 驱动包的坐标,在项目中pom.xml
文件中,只需要写下这段配置,就可以引入 MySQL 的驱动程序包了。
市面上还有很多构建工具,当前 Maven 依旧是主流构建工具,如下图是常用构建工具的占比:
# Maven 简介
Apache Maven是一个项目管理和构建工具,它基于项目对象模型(POM)的概念,通过一小段描述信息来管理项目的构建、报告和文档。官网。
上面的描述我们只需知道 Maven 是一个管理、构建项目的工具即可。Apache 是一个开源组织,将来我们会学习很多 Apache 提供的项目。
- Maven 模型:Maven 中有三个模型,咱们下面来简单介绍一下它们
- 项目对象模型(Project Object Model)
- 依赖管理模型(Dependency)
- 插件(Plugin)
上图所示就是 Maven 的模型,紫色框起来的部分就是用来完成 标准化构建流程 。假如我们需要编译,Maven 就提供一个而编译插件供我们使用,需要打包就提供一个打包插件给我们使用。
接下来我们看下 Maven 的项目对象模型,其实就是 Maven 将项目自己抽象为一个对象,它有自己的一些属性,比如专属的坐标等等,如下图就是一个 Maven 项目的坐标:
Maven 的依赖管理模型则是使用坐标来描述当前项目依赖哪些第三方 jar 包,如下图:
上面 Maven 模型图中,还有一个部分是仓库,那么如何理解仓库呢?
- Maven 仓库:
大家看下咱们之前的项目,依赖的 jar 包是放在项目的 lib 目录下的,那么如果使用 Maven,在项目中使用坐标来指定项目的依赖,那么依赖的 jar 包到底存储在什么地方呢?
Maven 管理的 jar 包是存储在我们本地仓库中的,当项目运行时可以从本地仓库中拿需要的 jar 包。
仓库的分类:
- 本地仓库:本地计算机上的一个目录
- 中央仓库:由 Maven 团队维护的全球唯一的仓库,https://repo1.maven.org/maven2/
- 远程仓库(私服):一般由公司团队搭建的私有仓库
当项目中使用坐标引入对应依赖的 jar 包后,首先会查找本地仓库中是否有对应的 jar 包:
- 有,则在项目直接引用;
- 无,则去中央仓库中下载对应版本的 jar 包到本地仓库。
如果使用的是远程仓库,则 jar 包的查找顺序为:本地仓库 --> 远程仓库 --> 中央仓库
# Maven 安装配置
Maven 安装与 MySQL 安装类似,解压 apache-maven-3.6.1-bin.zip
即可完成。
建议
建议解压缩到没有中文、特殊字符的路径下。
解压缩后的目录结果如:
bin
目录:存放的是可执行命令,mvn
命令需重点关注;conf
目录:存放 Maven 的配置文件,settings.xml
配置文件后面需要修改;lib
目录:存放 Maven 自身使用的 jar 包,Maven 也是 Java 开发的,所以也有依赖其他包
- 参照 JAVA_HOME、MYSQL_HOME 配置 Maven 的环境变量:
配置环境变量后,打开命令提示符进行验证,出现下面的提示信息表示安装成功:
- 配置本地仓库
修改 conf/settings.xml
中的 <localRepository></localRepository>
为一个本地目录作为本地仓库,用来存储 jar 包。
- 配置阿里云私服
Maven 的中央仓库在国外,同构中央仓库下载 jar 包速度比较慢,所以阿里都提供了一个远程仓库,我们要用的 jar 包在这个仓库里面基本上都有。
修改 conf/settings.xml
中的 <mirrors></mirrors>
标签,为其添加子标签:
<mirror>
<id>alimaven</id>
<name>aliyun maven</name>
<url>http://maven.aliyun.com/nexus/content/groups/public/</url>
<mirrorOf>central</mirrorOf>
</mirror>
2
3
4
5
6
# Maven 基本使用
通过以上的讲解,下面我们尝试将前面的 JDBC 演示项目修改为 Maven 项目结构:
- 首先创建一个 maven 项目
- 修改
pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<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.itheima</groupId>
<artifactId>jdbc-maven-demo</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.48</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.12</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13</version>
<!--<scope>test</scope>-->
</dependency>
</dependencies>
</project>
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
- 修改完成后整个项目的目录结构为:
按照上面的步骤我们就可以把之前的普通 Java 项目变更为 Maven 项目。
# Maven 常用命令
compile
: 编译clean
: 清理test
: 测试package
: 打包install
: 安装
下面咱们将本节课程 资料\代码\maven-project
导入 IDEA 来进行命令的演示,其项目结构如下图:
要演示上面的命令需要切换到项目的根目录下,也即是 pom.xml
文件所在的目录,在该目录下打开命令提示符:
- 编译命令:
mvn compile
执行 mvn compile
命令可以看到:
- 从阿里云下载编译需要的插件和 jar 包,在本地仓库也能看到下载好的插件和包;
- 在项目下会生成一个
target
目录,编译后的字节码文件就放在该目录下。
- 清理命令:
mvn clean
执行上述命令:
- 从阿里云下载清理所需要的插件 jar 包;
- 删除项目下的
target
目录
- 打包命令:
mvn package
执行上述命令:
- 从阿里云下载打包需要的插件 jar 包;
- 在项目
target
目录下生成一个 jar 包,将当前项目打成的 jar 包
- 测试命令:
mvn test
该命令会执行所有的测试代码,效果如下:
- 安装命令:
mvn install
该命令会将当前项目打成 jar 包,并安装到本地仓库。
# Maven 生命周期
Maven 构建项目的生命周期描述的是一次构建过程经理了多少个事件。
Maven 对象项目构建的生命周期划分为 3 套:
- clean:清理工作
- default:核心工作,例如编译、测试、打包、安装等
- site:产生报告、发布站点等。这套生命周期一般不会使用。
同一套生命周期内,执行后边的命令,前面的所有命令会自动执行。例如默认 default
生命周期如下:
当我们执行 install
安装命令时,它会先执行 compile
命令,再执行 test
命令,再执行 package
命令,最后执行 install
命令。
当我们执行 package
打包命令时,会先执行 compile
命令,再执行 test
命令,最后执行 package
命令。
默认的生命周期也有很多对应的命令,我们只关注常用的即可:
# IDEA 中使用 Maven
以后开发中我们会在 IDEA 中使用 Maven 管理项目,接下来我们讲下 Maven 在 IDEA 中的使用。
# IDEA 中配置 Maven 环境
- 在 IDEA 中 File -> Settings
- 搜索 maven
- 设置 IDEA 使用本地安装的 Maven,并修改配置文件路径
# Maven 坐标详解
什么是坐标?
- Maven 中的坐标是资源的唯一标识
- 使用坐标来定义项目或引入项目中需要的依赖
Maven 坐标主要组成部分
- groupId: 定义当前 Maven 项目隶属组织名称(通常是域名反写,例如:com.itheima)
- artifactId: 定义当前 Maven 项目名称(通常是模块名称,例如 order-service、goods-service)
- version: 定义当前项目版本号
如下图,就是使用坐标表示的一个项目:
注意
- 上面所说的资源可以是插件、依赖、当前项目
- 我们的项目如果被其他的项目依赖时,也是需要坐标来引入的
# IDEA 创建 Maven 项目
- 创建模块,选择 Maven,点击 Next
- 填写模块名称、坐标信息、点击
finish
,创建完成
创建好的项目目录结构如下:
- 编写并运行 HelloWorld
# IDEA 导入 Maven 项目
可以通过以下步骤进行项目的导入:
- 选择右侧 Maven 面板,点击
+
号
- 选中对应项目的 pom.xml 文件,双击即可
- 如果没有找到 Maven 面板,选择 View -> Appearance -> Tool Window Bars
可以通过下图所示进行命令的操作:
# 配置 Maven-Helper 插件
- 选择 IDEA 中 File -> Settings
- 选择 Plugins
- 搜索 Maven,选择第一个 Maven Helper,点击 Install 安装,弹出面板中点解 Accept
- 重启 IDEA
安装完插件后可以通过,选中项目右键进行相关命令的操作,如图:
# 依赖管理
# 使用坐标引入 jar 包
步骤如下:
- 在项目的
pom.xml
中编写<dependencies></dependencies>
标签 - 在
<dependencies></dependencies>
标签中使用<dependency></dependency>
引入坐标 - 定义坐标的
groupId
、artifactId
、version
<dependencies>
<!-- mysql 驱动坐标 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.48</version>
</dependency>
</dependencies>
2
3
4
5
6
7
8
- 点击刷新,使坐标生效
提示
具体的坐标我们可以到下面的网站进行搜索 https://mvnrepository.com/
# 快捷方式导入 jar 包坐标
每次需要引入 jar 包,都去对应的网站进行搜索是比较麻烦的,接下来个大家介绍一种快捷的方式
- 在
pom.xml
文件中按alt + insert
组合键,选择 Dependency
- 在弹出的面板中搜索对应坐标,然后双击选中坐标
- 点击刷新按钮,使生效
- 上面每次操作都需要手动点击刷新按钮,让引入的坐标生效。我们可以设置让其自动完成:File -> Settings
- 在弹出的面板中找到 Build Tools
- 选择 Any changes,点击 ok 即可生效
# 依赖范围
通过设置坐标的依赖范围(scope
),可以设置对应 jar 包的作用范围:编译环境、测试环境、运行环境。
如图,给 junit
依赖指定 <scope>test</scope>
,那么这个依赖就只能作用在测试环境,其他环境不能使用。
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13</version>
<scope>test</scope>
</dependency>
2
3
4
5
6
那么 scope
有哪些可能的取值呢?
依赖范围 | 编译 classpath | 测试 classpath | 运行 classpath | 例子 |
---|---|---|---|---|
compile | Y | Y | Y | logback |
test | - | Y | - | Junit |
provided | Y | Y | - | servlet-api |
runtime | - | Y | Y | jdbc 驱动 |
system | Y | Y | - | 存储在本地的 jar 包 |
- compile: 作用于编译环境、测试环境、运行环境。
- test: 作用于测试环境。比如junit的坐标,都会将scope的值设置为test
- provided: 编译环境、测试环境,我们后面学习的
servlet-api
,就是provided - runtime: 作用于测试环境、运行环境,比如jdbc驱动
注意
如果引入坐标不指定scope
标签时,默认就是compile
值。大部分jar包都是使用该值。