简单了解Maven与安装

embedded/2024/9/23 17:58:21/

Maven

1.Maven 简介

Maven 是 Apache 软件基金会(国外组织,专门维护开源项目)的一个开源项目,

是一个优秀的项目构建工具,

它用来帮助开发者管理项目中的 jar,

以及 jar 之间的依赖关系(在A.jar文件中用到了B.jar)、

完成项目的编译(把.java文件 编译为 .jar文件)、测试、打包和发布等工作。

(JAR文件是Java ARchive的缩写,是一种Java程序的归档文件格式。

它可以包含Java类、相关资源文件、库文件和元数据。

JAR文件通常被用来打包和分发Java应用程序或库,可以通过Java虚拟机(JVM)进行执行。

JAR文件是一种方便的方式来组织和传递Java程序,也常用于在网络上分发Java应用。)

如何管理?

maven将常用的jar收集起来,在他的服务器上存储,

每个jar都有一个独一无二的地址。

我们在开发期间,将jar包的地址配置在项目配置文件中即可,

借助maven就可以自动去官方下载jar文件到本地。

Maven 中的概念

pom(Project Object Model 项目对象模型)

Maven 管理的项目的根目录下都有一个 pom.xml 文件。

pom.xml 文件指示 Maven 如何工作。

在 pom.xml 文件中配置项目基本信息以及项目构建信息等。比如:项目坐标、项目依赖的 jar、插件、编译选项等。

一旦在 pom.xml 文件中配置了所依赖的 jar,Maven 会自动从构件仓库中下载相应的构件。

坐标

Maven 给每个 jar 定义了唯一的标志,这个在 Maven 中叫做项目的坐标,通过这个坐标可以找到你需要 用到的任何版本的 jar 包。

groupId、artifactId、packaging、version 的组合被称为项目的坐标,它们形成了项目的唯一标识,Maven 通过坐标来精确定位构件。其中 groupId、artifactId、version 是必须的,且这三项的值必须唯一,packaging 是可选的(默认为 jar)。

仓库

中央仓库全球共享,

先将 jar 从中央仓库下载到本地仓库,

然后在项目中引用本地仓库的 jar.

在项目中使用

2.Maven 开发环境搭建:

前提

安装 jdk

Maven 工作时需要通过网络下载各种插件以完成任务,因此应保证网络的通畅

2.1 下载 Maven 服务器

Maven 官网:http:// maven .apache. org

点击 download 进行下载如下图

2.2 安装,配置 Maven

点击下载二进制的 apache-maven -3.6.0-bin.zip 进行解压,”然后在系统环境中配置环境变量,在path中配置到bin目录,配置成功后输入命令mvn -version

表示 Maven 环境配置成功。

配置本地仓库地址

接下来根据情况在本地磁盘中建立通过 Maven 下载后 jar 文件所存储的文件夹,一般我们称为”仓库(repository)”;最终是如何将下载的 jar 文件存储到我们指定的仓库中呢?需要在 Maven 的服务器解压的文件中找到 conf 文件夹下的 settings.xml 文件进行修改,如下图所示:

配置阿里云 Maven 镜像仓库,下载速度更快

<mirror>

<id>aliMaven </id>

<name>aliyun Maven </name>

<url>http://Maven.aliyun.com/nexus/content/groups/public/</url>

<mirrorOf>central</mirrorOf>

</mirror>

2.3idea 中设置 Maven

2.4 创建 Maven 工程

pom.xml 配置

pom.xml 文件基本结构

1.项目基本信息

<modelVersion>4.0.0</modelVersion>

<groupId>org.example</groupId>

<artifactId>test</artifactId>

<version>1.0-SNAPSHOT</version>

2.指定编译时使用的 jdk 版本

<properties>

<maven.compiler.source>1.8</maven.compiler.source> <!-- 设置 Java 源代码兼容性 -->

<maven.compiler.target>1.8</maven.compiler.target> <!-- 设置编译的目标 JVM 版本 -->

</properties>

3.依赖信息

<dependencies>

<!--mysql-->

<dependency>

<groupId>mysql</groupId>

<artifactId>mysql-connector-java</artifactId>

<version>8.0.16</version>

</dependency>

</dependencies>

Maven 仓库官网(http://mvnrepository.com/)如下图所示:

在此官网就可以下载自己所需开发 jar 包,继续点击链接打开如下:

  1. 构建信息

<build>...</build>

4.Maven 命令

Maven 常用命令

  1. clean 删除编译的 target

  2. compile 编译

  3. package 打包

  4. install 安装 package 和 install都能打包

package 和 install 区别:

package打包在工程里

install打包在本地仓库里

5.打包 javaSE 项目案例

添加打包依赖

<build>

<plugins>

<plugin>

<groupId>org.apache.maven.plugins</groupId>

<artifactId>maven-assembly-plugin</artifactId>

<configuration>

<descriptorRefs>

<!--**给 jar 包起的别名**-->

<descriptorRef>jar-with-dependencies</descriptorRef>

</descriptorRefs>

<archive>

<manifest>

<addClasspath>true</addClasspath>

<classpathPrefix>lib/</classpathPrefix>

<!--**添加项目中主类**-->

<mainClass>com.ffyc.chatrom.client.frame.Run</mainClass>

</manifest>

</archive>

</configuration>

<executions>

<execution>

<id>make-assembly</id>

<phase>package</phase>

<goals>

<goal>single</goal>

</goals>

</execution>

</executions>

</plugin>

</plugins>

</build>

执行 maven 命令

生成 jar

复制出 jar 包,到桌面.


http://www.ppmy.cn/embedded/112800.html

相关文章

OpenAI O1:人工智能推理能力的新里程碑

引言 北京时间9月13日凌晨&#xff0c;OpenAI在没有任何预告的情况下&#xff0c;正式发布了其首款具有推理能力的模型——OpenAI O1。这一模型的发布&#xff0c;不仅标志着人工智能能力的新水平&#xff0c;也预示着AI技术发展的新范式。本文将详细解析OpenAI O1模型的技术特…

【Java】线程状态:线程生命周期的六个阶段

欢迎浏览高耳机的博客 希望我们彼此都有更好的收获 感谢三连支持&#xff01; 在Java中&#xff0c;线程可以处于多种状态&#xff0c;这些状态描述了线程的生命周期。了解这些状态及其转换条件对于编写高效且无错误的多线程应用程序至关重要。本文将总结Java线程的几种状态&am…

单组件的编写

项目搭好了&#xff0c;第一个需要了解的是 Vue 组件的变化&#xff0c;由于这部分篇幅会非常大&#xff0c;所以会分成很多个小节&#xff0c;一部分一部分按照开发顺序来逐步了解。 因为 Vue 3 对 TypeScript 的支持真的是太完善了&#xff0c;并且 TypeScript 的发展趋势和…

从零开始搭建 PHP

&#x1f6e0;️ 从零开始搭建 PHP 环境&#xff1a;详细教程 PHP&#xff08;Hypertext Preprocessor&#xff09;是最流行的后端脚本语言之一&#xff0c;广泛用于构建动态网站和 Web 应用程序。在开始 PHP 开发之前&#xff0c;首先需要搭建 PHP 运行环境。无论你使用的是 …

Python---爬虫

文章目录 目录 前言 一.Http请求/响应模块 requests模块 二.文本筛选模块 re模块 XPath模块 XPath 路径表达式 XPath 语法元素 三. 爬虫模板 爬虫案例 前言 Python爬虫是一种通过自动化程序爬取互联网上的信息的技术。爬虫可以自动访问网页并提取所需的数据&#xff0c;比…

56. 合并区间

思路 对区间进行排序&#xff1a;按每个区间第一个数的大小进行升序排序 排好序后&#xff0c;初始化 dp[0]第一个区间 则下一个区间是否为一个单独区间&#xff0c;只需要看 这个区间的第一个数是否小于等于上一个区间的第二数&#xff0c;小于等于&#xff0c;则在上一个区间…

大数据之Spark(二)

9.4.3、RDD持久化 RDD之间进行相互迭代计算&#xff08;Transformation的转换&#xff09;&#xff0c;当执行开启&#xff0c;新RDD的生成代表旧RDD消失。如果有的rdd需要重复使用就需要将rdd缓存&#xff0c;rdd.cache()或rdd.persist()。清理缓存rdd.unpersist() 缓存特点&…

Linux基础---07文件传输

Linux文件传输地图如下&#xff0c;先选取你所需的场景&#xff0c;若你是需要Linux和Linux之间传输文件就查看SCP工具即可。 一.下载网站文件 前提是有网&#xff1a; 检查网络是否畅通命令&#xff1a;ping www.baidu.com&#xff0c;若有持续的返回值就说明网络畅通。Ctr…