【JavaEE】Maven简介与实用指南:项目构建和依赖管理的高效工具

发布于:2024-05-16 ⋅ 阅读:(22) ⋅ 点赞:(0)


Maven

什么是 Maven

官⽅对于 Maven 的描述:

Maven 是⼀个项⽬管理⼯具。基于 POM(Project Object Model,项⽬对象模型)的概念,Maven 可以通过⼀⼩段描述信息来管理项⽬的构建,报告和⽂档的项⽬管理⼯具软件。

⼤⽩话: Maven 是⼀个项⽬管理⼯具, 通过 pom.xml ⽂件的配置获取 jar 包,⽽不⽤⼿动去添加 jar 包

为什么学 Maven

⼀句话: 简单, ⽅便, 提⾼我们的开发效率, 减少我们的开发Bug.

Maven 提供的功能⾮常多, Maven 在咱们课程中的体现主要是以下两个⽅⾯:

  1. 项⽬构建

  1. 管理依赖
<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
     <dependency>
         <groupId>mysql</groupId>
         <artifactId>mysql-connector-java</artifactId>
         <version>5.1.49</version>
     </dependency>

这是5.1.49的 MySQL

可以理解为坐标,引入后记得刷新

创建一个Maven项目

IDEA本⾝已经集成了Maven, 我们可以直接使⽤, ⽆需安装

Maven 只是一个工具,和 idea 没有关系,只是 idea 集成了 Maven

这些是Maven命令

在这里插入图片描述

依赖传递

早期我们没有使⽤maven时, 向项⽬中添加依赖的jar包,需要把所有的jar包都复制到项⽬⼯程下.

⽐如 A 依赖 B, B 依赖 C, 那么 A 项⽬引⼊ B 的同时, 也需要引⼊ C, 如果我们⼿动管理这个依赖, 这个过程就会⽐较⿇烦, 我们需要知道每个库都依赖哪些库, 以及这些依赖之间的版本是如何关联的

⽐如我们要吃⽕锅, 需要有锅, 有调料, 有⻝材, 以及确认什么样的锅, 什么样的⻝材.

⽐如去医院看病, 需要带上以往的病历, 检查结果, 处⽅等, 并且要确认带的资料是正确的, 如果⽇期错了, 或者患者错了, 带少了, 就需要回去重新拿

但使⽤maven的话, 就可以避免管理所需依赖的关系。我们只需要在 pom ⽂件中, 定义直接依赖就可以了, 由于 maven 的依赖具有传递性,所以会⾃动把所依赖的其他jar包也⼀起导⼊

⽐如吃⽕锅, 现在我们可以点⼀个海底捞外卖, 直接就把所有⻝材都送过来了, 包括什么锅, 配什么菜.

⽐如去医院看病, 借助"互联⽹", 实现了信息共享, 只需要带上⾝份证, 以往的病历和检查结果就都可以看到了
在这里插入图片描述

如上图, 项⽬ A 通过 Maven 引⼊ Jar A 时, 会⾃动引⼊ Jar B 和 Jar C.

Jar A 和项⽬ B 就是项⽬ A 的直接依赖。Jar B, Jar C 是间接依赖

直接依赖:在当前项⽬中通过依赖配置建⽴的依赖关系

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

依赖排除

当前阶段我们需要依赖的库并不多, 但随着项⽬的越来越复杂, 库之间的依赖关系也会变得越来越复杂.

如上图中, 如果项⽬A不需要Jar B,也可以通过排除依赖的⽅式来实现

排除依赖:

指主动断开依赖的资源。(被排除的资源⽆需指定版本)

⽐如, 我下了⼀个快递单⼦, 默认会有⼀个服务, 就是快递⼩哥会上⻔取件, 但是我刚好要出⻔, ⽽且顺路经过站点, 也可以选择⾃⼰送过去

<dependency>
	<groupId>org.springframework</groupId>
	<artifactId>spring-core</artifactId>
	<version>6.0.6</version>

	<!--排除依赖-->
	<exclusions>
		<exclusion>
			<artifactId>spring-jcl</artifactId>
			<groupId>org.springframework</groupId>
		</exclusion>
	</exclusions>
</dependency>

maven还有⼀些功能是依赖调解, 可选依赖等

依赖调解:

当项⽬中的依赖存在依赖冲突时, 例如 存在这样的依赖:

A->B->C->X(1.0)

A->D->X(2.0)

Maven会采⽤最短路径优先的原则去选择依赖,这⾥2的依赖路径更短,所以会选择X(2.0), 当然我们也可以选择指定某个依赖的版本

当然也可以指定X的版本

Maven 仓库

我们通过短短⼏⾏代码, 就把依赖jar包放在了项⽬⾥, 具体是如何做的呢?

<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.49</version>
        </dependency>

这个代码, 我们称之为 “坐标”, 也就是唯⼀的.

在Maven中, 根据 groupId、artifactId、version 的配置, 来唯⼀识别⼀个 jar 包, 缺⼀不可.

当我们在pom⽂件中配置完依赖之后, 点击刷新, Maven会根据坐标的配置, 去仓库⾥寻找Jar包, 并把他下载下来, 添加到项⽬中. 这个Jar包下载的地⽅就称为仓库

仓库:⽤于存储资源,管理各种jar包

Maven仓库的本质就是⼀个⽬录(⽂件夹),这个⽬录被⽤来存储开发中所有依赖(jar包, 插件等).

Maven仓库分为两⼤类: 本地仓库和远程仓库. 其中远程仓库⼜分为中央仓库私服其他公共库

  1. 中央仓库
  2. 本地仓库
  3. 私服
本地仓库

本地仓库: ⾃⼰计算机上的⼀个⽬录(⽤来存储jar包)

当项⽬中引⼊对应依赖jar包后,⾸先会查找本地仓库中是否有对应的jar包

  • 如果有,则在项⽬直接引⽤
  • 如果没有,则去中央仓库中下载对应的jar包到本地仓库

在这里插入图片描述

左边是我们的项目

本地仓库地址可以通过Maven配置查看:

File -> Settings
在这里插入图片描述

但注意,这里不要包含中文,我这里也要改

这个C:\Users\幽琴健\ .m2就是Maven相关的地址

如何修改呢?


在这里插入图片描述

查看该仓库⽬录, 可以看到该⽬录下有很多的jar(最开始是空的, 随着Maven的使⽤, 该仓库下⽂件会越来越多)

中央仓库

中央仓库: maven 软件中内置⼀个远程仓库地址,就是中央仓库,服务于整个互联⽹. 由 Maven 团队维护,全球唯⼀

仓库地址:https://repo1.maven.org/maven2/

可以通过 https://mvnrepository.com 这个⽹站来查询并下载

我们可以把⾃⼰写好的Jar包上传到中央仓库(具备⼀定的要求), 也可以从中央仓库下载 Jar 包

查找Jar的坐标

  1. 访问 https://mvnrepository.com/

在这里插入图片描述

注意这个网站只是查找,中央仓库不是这样的,中央仓库就是一个大型文件夹

  1. 进⾏查找, ⽐如mysql

在这里插入图片描述

  1. 选择要添加的Jar包版本

  2. 查看Jar包对应坐标

在这里插入图片描述

私服

私有服务器, 也称为私服

私服: ⼀般由公司团队搭建的私有仓库.

私服属于某个公司,或者某个部⻔, 往往需要⼀定权限.

有了私服之后, Maven依赖下载的顺序⼜发⽣了变化

在这里插入图片描述

当Maven需要下载资源的时候

  1. 先从本地仓库获取, 本地仓库存在, 则直接返回
  2. 如果本地仓库没有, 就从私服请求, 私服存在该资源, 就直接返回
  3. 如果私服上不存在该资源,则从中央仓库下载, 中央仓库不存在, 就报错了…
  4. 如果中央仓库中存在, 就先缓存在私服上之后,再缓存到本地仓库⾥, 再为Maven的下载请求提供服务

私服是很多⼈在使⽤的, 所以只需要第⼀个使⽤者下载⼀次就可以了

Maven设置国内源

因为中央仓库在国外, 所以下载起来会⽐较慢, 所以咱们选择借助国内⼀些公开的远程仓库来下载资源接下来介绍, 如何设置国内源

配置当前项⽬setting

File -> Settings

在这里插入图片描述

  1. 查看配置⽂件的地址, 如上图所⽰, Maven配置⽂件地址为: D:\Maven\.m2\settings.xml

不同电脑设置的Maven路径不同

settings 和 repository 可以修改设置为其他路径, 两个路径都不要有中⽂

  1. 配置国内源

Maven 仓库默认在国外https://mvnrepository.com/, 国内使⽤时会⽐较慢,我们可以更换为阿⾥云的仓库

也可以选择别的仓库, 参考: Maven 镜像地址⼤全

打开settings.xml, 在 mirrors 节点上,添加内容如下:

设置新项⽬的setting

上述配置的内容, 只对当前项⽬⽣效, 为了让后续新建的项⽬也⽣效, 需要重新设置⼀下新项⽬的Settings

当前项⽬和新项⽬共⽤⼀个setttings⽂件即可, 所以新项⽬的设置, 只需要确认⼀下settings⽂件的路径即可.

在这里插入图片描述

在这里插入图片描述