Maven环境配置及介绍[通俗易懂]

Maven环境配置及介绍[通俗易懂]Maven环境配置及介绍Maven的出现是为了解决jar包管理的问题,可以通过简短的描述信息,进行项目管理的工具软件。1.maven的安装下载地址:http://maven.apache.org/downloa/d.cgi2.环境变量配置maven环境变量配置,配置方式跟jdk有些类似。新建环境变量MAVEN_HOME(值为maven的根目录)、然后在PATH环境变量里加入%MAVEN_HOME%\bin;即可。使用快捷键win+R,在黑窗口输入mvn–v进行查看,显示如下就表

大家好,又见面了,我是你们的朋友全栈君。

Maven环境配置及介绍

Maven的出现是为了解决jar包管理的问题,可以通过简短的描述信息,进行项目管理的工具软件。

1.maven的安装

下载地址:http://maven.apache.org/downloa/d.cgi

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VaLZiKiF-1624585976710)(C:\Users\Y\AppData\Roaming\Typora\typora-user-images\image-20210621162744807.png)]

2.环境变量配置

maven环境变量配置,配置方式跟jdk有些类似。新建环境变量MAVEN_HOME(值为maven的根目录)、然后在PATH环境变量里加入%MAVEN_HOME%\bin;即可。
在这里插入图片描述
在这里插入图片描述

使用快捷键win+R,在黑窗口输入mvn –v进行查看,显示如下就表示配置成功了

在这里插入图片描述

3.配置settings.xml文件

有了maven后,就不需要再频繁的下载jar包了,只需要引入一个坐标,就可以找到对应的jar。所有的jar包都放在仓库(repository)中,输入对应的坐标就可以再仓库中找到了。

在安装的目录下找到conf

在这里插入图片描述

xml配置文件中的很多英文注释,如果没有能力区阅读可以忽略,但需要在文件中配置部分路径。

在这里插入图片描述

复制53行到末尾配置自己的仓库地址

<localRepository>D:\repository</localRepository>

由于中央仓库式国外的大佬搞出来的,所以使用外网下载jar包会很慢,所以需要使用到我们国内的大佬们去搭建的私服镜像克隆了中央仓库以供使用,当然xx自由者可直接去中央仓库下载:https://mvnrepository.com/,国内的镜像用阿里的就可以了,当然还有其他的镜像仓库可以去百度,这里是一个阿里云镜像。

<!-- 阿里云镜像 -->
    <mirrors>
        <mirror>
            <id>alimaven</id>
            <name>aliyun maven</name>
            <!-- https://maven.aliyun.com/repository/public/ -->
            <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
            <mirrorOf>central</mirrorOf>
        </mirror>
    </mirrors>
懒人式CTRL大法:
<?xml version="1.0" encoding="UTF-8"?>

<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd">
		  <localRepository>D:\repository</localRepository>
 <!-- 阿里云镜像 -->
    <mirrors>
        <mirror>
            <id>alimaven</id>
            <name>aliyun maven</name>
            <!-- https://maven.aliyun.com/repository/public/ -->
            <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
            <mirrorOf>central</mirrorOf>
        </mirror>
    </mirrors>

		  </settings>
仓库知识急救区
  1. 本地仓库:就是Maven在本机存储构件的地方。maven的本地仓库,在安装maven后并不会创建,它是在第一次执行maven命令的时候才被创建。maven本地仓库的默认位置:在用户的目录下都只有一个.m2/repository/的仓库目录;可以修改。
  2. 中央仓库:包含了绝大多数流行的开源Java构件,以及源码、作者信息、SCM、信息、许可证信息等。开源的Java项目依赖的构件都可以在这里下载到。
  3. 私服:是一种特殊的远程仓库,它是架设在局域网内的仓库。

4.IDEA集成maven

创建一个Maven项目:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

maven项目在默认情况下会产生JAR文件,编译后的classes会放在target/classes下面,JAR文件放在target下面。

创建完maven项目后,系统会提示导入Maven:
在这里插入图片描述

这时可以先不导入,因为系统默认的是IDEA的Maven,也可以用,但是没有配置仓库的位置。所以需要在File–>setting中找到maven,配置好自己的路径。

在这里插入图片描述

5.maven常用命令

常用命令
编译源代码 mvn compile
编译测试代码 mvn test-compile
清除产生的项目 mvn clean
运行测试 mvn test
产生site mvn site
打包 mvn package
在本地Repository中安装jar mvn install
上传项目到远程仓库 mvn deploy
注意:如果出现报错信息,需要在pom.xml中设置jdk1.8。

在这里插入图片描述

设置插件如下:

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <version>3.6.0</version>
    <configuration>
        <source>1.8</source> <!-- 源代码使用jdk1.8支持的特性 -->
        <target>1.8</target> <!-- 使用jvm1.8编译目标代码 -->
               <compilerArgs> <!-- 传递参数 --通过支持反射拿到方法名>
                    <arg>-parameters</arg>
                    <arg>-Xlint:unchecked</arg>
                    <arg>-Xlint:deprecation </arg>
              </compilerArgs>
    </configuration>
</plugin>

6.maven项目生命周期(Lifecycle)

clean: 主要目的是清理项目(第一生命周期)
  • ​ pre-clean: 执行一些清理前需要完成的工作
  • ​ clean: 清理上一次构建生成的文件
  • ​ post-clean: 执行一些清理后需要完成的工作
default:定义了真正构建时所需要执行的所有步骤,它是生命周期中最核心的部分

​ validate

​ initialize

​ generate-sources

​ process-sources: 处理项目主资源文件。一般来说,是对src/main/resources目录的内容 进行变量替换等工作后,复制到项目输出的主classpath目录中

​ generate-resources

​ process-resources

compile: 编译项目的主源码。一般来说,是编译src/main/java目录下的Java文件至项目输出的主classpath目录中target

​ process-classes

​ generate-test-sources

​ process-test-sources: 处理项目测试资源文件。一般来说,是对src/test/resources目录 的内容进行变量替换等工作后,复制到项目输出的测试classpath目录中

​ generate-test-resources

​ process-test-resources

test-compile: 编译项目的测试代码,一般来说,是编译src/test/java目录下的Java文件至项目输出的测试classpath目录中

​ process-test-classes

@Test

test: 使用单元测试框架运行测试,测试代码不会打包或部署

​ prepare-package

package: 接受编译好的代码,打包成可发布的格式,如JAR

​ pre-integration-test

​ integration-test

​ post-integration-test

​ verify

install: 将包安装到Maven本地仓库,供本地其他Maven项目使用
deploy: 将最终的包复制到远程仓库(私服),供其他开发人员和Maven项目使用
site生命周期: 建立和发布项目站点,Maven能够基于POM所包含的信息,自动生成站点

​ pre-site: 执行一些在生成项目站点之前需要完成的工作

​ site: 生成项目站点文档

​ post-site: 执行一些在生成项目站点之后需要完成的工作

​ site-deploy: 将生成的项目站点发布到服务器上

7.pom.xml基本配置说明

<!--固定的-->
<modelVersion>4.0.0</modelVersion>
<!--描述当前项目的组织-->
<groupId>cn.cdqf</groupId>
<!--描述当前项目的唯一id-->
<artifactId>maven_01</artifactId>
<version>1.0-SNAPSHOT</version>
<!--定义打包的方式 jar:默认方式 war: web项目最终打成war包 放在服务器上运行 pom:其它项目的父亲 -->
<packaging>war</packaging>
<!--spring jar包有50个 组织+id+版本 定义常量 -->
<properties>
    <junit.version>4.12</junit.version>
</properties>
<!--项目所有依赖都写在这里面 每一个<dependency>就表示一个依赖 groupId+artifactId+version :精确在仓库中定位一个jar -->
<dependencies>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>${junit.version}</version>
        <!--依赖范围-->
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>io.springfox</groupId>
        <artifactId>springfox-swagger-ui</artifactId>
        <version>2.9.2</version>
        <!--排除当前jar依赖的某个jar包 一般在jar包冲突的时候使用-->
        <exclusions>
            <exclusion>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-api</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
</dependencies>

8.scope依赖范围

scope定义依赖的范围,默认是compile

compile

编译依赖范围,使用此依赖范围对于编译、测试、运行三种classpath都有效,即在编译、测试和运行时都要使用该依赖jar包;

test

测试依赖范围,只对测试有效,表明只在测试的时候需要,在编译和运行时将无法使用该类依赖,如 junit;

provided

已提供依赖范围。编译和测试有效,运行无效。如servlet-api,在项目运行时,tomcat等容器已经提供,无需Maven重复引入;

runtime

运行时依赖范围。测试和运行有效,编译无效。如 jdbc 驱动实现,编译时只需接口,测试或运行时才需要具体的 jdbc 驱动实现;

system

系统依赖范围,使用system范围的依赖时必须通过systemPath元素显示地指定依赖文件的路径,不依赖Maven仓库解析,所以可能会造成建构的不可移植,谨慎使用

9.jar包的冲突

传递依赖:某个SDK会依赖某些jar包,如果这个SDK是写的比较好的项目,当别人用到该SDK的时候需要导入SDK的jar包,同时也会传递导入SDK中依赖的jar包。

引入条件:

  1. 第一原则:路径优先
  2. 第二原则:第一声明者优先

排除jar包的依赖冲突:

<dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-swagger-ui</artifactId>
    <version>2.9.2</version>
    <!--排除当前jar依赖的某个jar包 一般在jar包冲突的时候使用-->
    <exclusions>
        <exclusion>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
        </exclusion>
    </exclusions>
</dependency>

10.常用插件

插件名称 用途 来源
maven –clean -plugin 清理项目 Apache
maven –compile -plugin 编译项目 Apache
maven –deploy -plugin 部署项目 Apache
maven –install -plugin 安装项目 Apache
maven –resources -plugin 处理资源文件 Apache
maven –site -plugin 生成站点 Apache
maven –surefire -plugin 执行测试 Apache
maven –jar -plugin 构建JAR项目 Apache
maven –war -plugiin 构建war项目 Apache
maven –shade -plugin 构建包含遗憾的JAR包 Apache
maven –changelog -plugin 生产版本控制变更报告 Apache
maven –checkstyle -plugin 生成checkStyle报告 Apache
maven –javadoc –plugin 生成JavaDoc文档 Apache
maven –pmd –plugin 生成PMD报告 Apache
maven –project –info -reports –plugin 生成项目信息报告 Apache
maven –surefire –plugin 生成单元测试报告 Apache
maven -archetype –plugin 基于Archetype生成项目骨架 Apache
maven –assembly –plugin 构建自定义格式的分布包 Apache
maven –dependency –plugin 依赖分析及控制 Apache
maven –enforcer –plugin 定义规则并强制要求遵守 Apache
maven –pgp –plugin 为项目构建生成PGP签名 Apache
maven -invoke –plugin 自动运行Maven项目构建并验证 Apache
maven –release –plugin 自动项目版本发布 Apache
maven –scm –plugin 集成版本控制系统 Apache
maven –source –plugin 生成源码包 Apache
properties –maven –plugin 从properties文件读写Maven属性 Codehaus
sql –maven –plugin 运行SQL脚本 Codehaus
tomcat –maven –plugin 启动、停止、部署项目 Codehaus
versions –maven –plugin 自动化批量更新POM版本 Codehaus
cargo –maven –plugin 启动/停止/配置各类Web容器自动化部署Web项目 Cargo
jetty –maven –plugin 集成jetty容器,实现快速开发测试 Eclipse

11.maven的聚合

聚合的好处:模块重用

  1. 新建一个emptyproject
    在这里插入图片描述

  2. 新建模块

    • 父模块

在这里插入图片描述

   - Util工具模块

在这里插入图片描述

   - Dao模块

在这里插入图片描述

   - service模块

在这里插入图片描述

   - Controller模块

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/146578.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • WeakHashMap,源码解读[通俗易懂]

    WeakHashMap,源码解读[通俗易懂]概述WeakHashMap也是Map接口的一个实现类,它与HashMap相似,也是一个哈希表,存储key-valuepair,而且也是非线程安全的。不过WeakHashMap并没有引入红黑树来尽量规避哈希冲突带来的影响,内部实现只是数组+单链表。此外,WeakHashMap与HashMap最大的不同之处在于,WeakHashMap的key是“弱键”(weakkeys),即当一个key不再正…

  • SVM和logistic regression的一些对比

    SVM和logistic regression的一些对比

  • CentOS系统下Redis安装和自启动配置的步骤

    CentOS系统下Redis安装和自启动配置的步骤

    2021年10月11日
  • python安装cpickle_python中cPickle

    python安装cpickle_python中cPickle在python中,一般可以使用pickle类来进行python对象的序列化,而cPickle提供了一个更快速简单的接口,如python文档所说的:“cPickle–Afasterpickle”。cPickle可以对任意一种类型的python对象进行序列化操作,比如list,dict,甚至是一个类的对象等。而所谓的序列化,我的粗浅的理解就是为了能够完整的保存并能够完全可逆的恢复。在cPic…

  • LM优化算法_lm算法内参计算

    LM优化算法_lm算法内参计算LM算法理论知识梯度下降高斯牛顿Levenberg–Marquardt算法框架算法的整体流程求解器update流程说明算法实现头文件cpp算法调用LM优化算法,是一种非线性优化算法,其可以看作是梯度下降和高斯牛顿法的结合。综合了梯度下降对初值不敏感和高斯牛顿在最优值附近收敛速度快的特点。本人非数学专业,且对算法理解可能不到位,详细的算法推导及各个优化算法之间的关系,非常推荐看**《METHODSFORNON-LINEARLEASTSQUARESPROBLEMS》**,其介绍更详细也更专业。

  • java uniqueresult_「uniqueresult」hibernate uniqueResult方法 – seo实验室[通俗易懂]

    java uniqueresult_「uniqueresult」hibernate uniqueResult方法 – seo实验室[通俗易懂]uniqueresult数据库中根据你的查询条件只会返回唯一结果,就可以用uniqueresult这个方法!否则就用list();其返回类型为ObjectuniqueResult()方法通常是在业务方法查询语句中用到的,比如(Usersroles)getsession().createQuery(“selecturfromUsersRolesurwhereur.role.id=?…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号