Maven基础
1.Maven简介
1.1 传统项目管理
分析:
- jar包不统一,jar包不兼容
- 工程升级维护过程操作繁琐
- …
1.2 概念
Maven的本质是一个项目管理工具,将项目开发和管理过程抽象成一个项目对象模型(POM)
POM(Project Object Model):项目对象模型
Maven的作用:
- 项目构建:提供标准的、跨平台的自动化项目构建方式
- 依赖管理:方便快捷的管理项目依赖的资源(jar包),避免资源间版本冲突问题
- 统一开发结构:提供标准的、统一的项目结构
2.下载与安装
1.下载:
下载地址:http://maven.apache.org/download.cgi
2.安装
Maven属于绿色版软件,解压即安装
3.环境变量配置
依赖Java,需要配置JAVA_HOME
设置Maven自身的运行环境,需要配置MAVEN_HOME
配置步骤:
-
右击桌面计算机/此电脑–选择属性–选择高级系统设置–选择环境变量
-
在下方系统变量点击新建MAVEN_HOME(JAVA_HOME已配置,配置方法相同)
-
添加path路径
测试环境变量结果:cmd中使用mvn命令
出现以下结果,则配置成功:
3.Maven基础概念
3.1 仓库
仓库:用户存储资源,包含各种jar包
仓库分类:
- 本地仓库:自己电脑上存储资源的仓库,连接远程仓库获取资源
- 远程仓库:非本机电脑上的仓库,为本地仓库提供资源
- 中央仓库:Maven团队维护,存储所有资源的仓库
- 私服:部门/公司范围内存储资源的仓库,从中央仓库获取资源
私服的作用:
- 保存具有版权的资源,包含购买或自主研发的jar
- 中央仓库中的jar都是开源的,不能存储具有版权的资源
- 一定范围内共享资源,仅对内部开放,不对外共享
3.2 坐标
什么是坐标?
- Maven中的坐标用户描述仓库中资源的位置
- https://repo1.maven.org/maven2/
Maven坐标主要组成
- groupId:定义当前Maven项目隶属组织名称(通常是域名反写,例如:org.mybatis)
- artifactId:定义当前Maven项目名称(通常是模块名称,例如:CRM、SMS)
- version:定义当前项目版本号
- packaging:定义该项目的打包方式
Maven资源:https://mvnrepository.com/
Maven坐标的作用:
- 使用唯一标识,唯一定位资源位置,通过该标识可以将资源的识别与下载工作交由机器完成
3.3 仓库配置
Maven启动后,会自动保存下载的资源到本地仓库
- 默认位置:<localRepository>${user.home}/.m2/repository</localRepository>
- 当前目录位置为登录用户名所在目录下的.m2文件夹中
- 自定义位置:<localRepository>D:\maven\repository</localRepository>
- 当前目录位置为D:\maven\repository文件夹中,要求此目录同级必须有一个setting.xml文件
镜像仓库配置
-
在用户setting文件中配置阿里云镜像仓库,在<mirrors>标签中添加以下内容
-
<!--配置具体的仓库的下载镜像--> <mirror> <!--此镜像的唯一标识,用来区分不同的mirror元素--> <id>nexus-aliyun</id> <!--对哪种仓库进行镜像,简单说就是代替哪个仓库--> <mirrorOf>central</mirrorOf> <!--镜像名称--> <name>Nexus aliyun</name> <!--镜像URL--> <url>http://maven.aliyun.com/nexus/content/groups/public</url> </mirror>
全局setting与用户setting区别:
- 全局setting定义了当前计算机中Maven的公共配置
- 用户setting定义了当前用户的配置
4.第一个Maven项目(手工制作)
4.1 Maven工程目录结构
工程项目–>src文件夹 --> main文件夹/test文件夹 --> main和test两个文件夹下都有java文件夹和resources文件夹
在src同层目录下创建pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://maven.apache.org/POM/4.0.0">
<modelVersion>4.0.0</modelVersion>
<groupId>com.itheima</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>
</dependencies>
</project>
在src/main/java下创建包和类:
package com.itheima;
public class Demo{
public String say(String name){
System.out.println("hello " + name);
return "hello " + name;
}
}
在src/main/test下创建包和类:
package com.itheima;
import org.junit.Test;
import org.junit.Assert;
public class DemoTest{
@Test
public void testSay(){
Demo d = new Demo();
String ret = d.say("maven");
Assert.assertEquals("hello maven",ret);
}
}
4.2 构建命令
Maven构建命令使用mvn开头,后面添加功能参数,可以一次执行多个命令,使用空格分隔
mvn compile #编译
mvn clean #清理
mvn test #测试
mvn package #打包
mvn install #安装到本地
进入cmd,进入到项目文件夹位置:输入指令
4.3 插件创建工程
创建工程:
-
mvn archetype:generate -DgroupId={project-package} -DartifactId={project-name} -DarchetypeArtfactId=maven-archetype-quickstart -DinteractiveMode=false
创建Java工程
-
mvn archetype:generate -DgroupId=com.itheima -DartifactId=java-project -DarchetypeArtifactId=maven-archetype-quickstart -Dversion=0.0.1-snapshot -DineractiveMode=false
创建web工程
-
mvn archetype:generate -DgroupId=com.itheima -DartifactId=web-project -DarchetypeArtifactId=maven-archetype-webapp -Dversion=0.0.1-snapshot -DineractiveMode=false
5.第一个Maven项目(IDEA生成)
5.1 配置Maven
IDEA对3.6.2及以上版本存在兼容性问题,为避免冲突,IDEA中安装3.6.1版本
5.2 Setting中没有Maven的问题
在配置时遇到一个问题,IDEA的设置页面Setting中没有Maven选项。百度了解:在Setting中Plugins插件页面Maven Integration未勾选,勾选重启就行。但本人的IDEA中没有这个插件,取而代之的是:Maven和Maven Extension,将这两个插件勾选重启,Setting左侧就有Maven选现了。(IDEA版本:2019.3)
5.3 创建Maven项目
目录结构:
资源文件中的类:
package com.itheima;
public class Demo {
public String say(String name){
System.out.println("hello "+name);
return "hello "+name;
}
}
测试文件中的类:
package com.itheima;
import org.junit.Assert;
import org.junit.Test;
public class DemoTest {
@Test
public void testSay(){
Demo demo = new Demo();
String str = demo.say("maven");
Assert.assertEquals("hello maven",str);
}
}
5.4 运行相关配置
5.5 插件
tomcat7运行插件
<?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/maven-v4_0_0.xsd">
<!--指定pom的模型版本-->
<modelVersion>4.0.0</modelVersion>
<!--打包方式,web工程打包为war,java工程打包为jar-->
<packaging>war</packaging>
<!--组织id,一般用域名倒写-->
<groupId>com.itheima</groupId>
<!--项目id-->
<artifactId>web01</artifactId>
<!--版本号:release(完成版),snapshot(开发版)-->
<version>1.0-SNAPSHOT</version>
<!--设置当前工程的所有依赖-->
<dependencies>
<!--具体依赖-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
</dependencies>
<!--构建-->
<build>
<!--设置插件-->
<plugins>
<!--具体的插件配置-->
<plugin>
<!--<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat8-maven-plugin</artifactId>
<version>2.2</version>-->
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.2</version>
<configuration>
<port>80</port>
<path>/</path>
</configuration>
</plugin>
</plugins>
</build>
</project>
6.依赖管理
6.1 依赖配置
依赖指当前项目运行所需的jar,一个项目可以设置多个依赖
格式:
<!--设置当前工程的所有依赖-->
<dependencies>
<!--设置具体依赖-->
<dependency>
<!--依赖所属群组id-->
<groupId>junit</groupId>
<!--依赖所属项目id-->
<artifactId>junit</artifactId>
<!--依赖版本号-->
<version>4.12</version>
</dependency>
</dependencies>
6.2 依赖传递
依赖具有传递性:
- 直接依赖:在当前项目中通过依赖配置建立的依赖关系
- 间接依赖:被依赖的资源如果依赖其他资源,当前项目间接依赖其他资源
依赖传递冲突问题:
- 路径优先:当依赖中出现相同资源时,层级越深,优先级越低,层级越浅,优先级越高
- 声明优先:当资源在相同层级被依赖时,配置顺序靠前的覆盖配置顺序靠后的
- 特殊优先:当同级配置了相同资源的不同版本,后配置的覆盖先配置的
6.3 可选依赖
可选依赖指对外隐藏当前所依赖的资源—不透明
<optional>:隐藏,设置为true生效,默认为false(不隐藏)
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<optional>true</optional>
</dependency>
6.4 排除依赖
排除依赖指主动断开依赖的资源,被排除的资源无需指定版本—不需要
<exclusion>:排除,设置要排除依赖信息
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<exclusions>
<exclusion>
<groupId>org.hamcrest</groupId>
<artifactId>hamcrest-core</artifactId>
</exclusion>
</exclusions>
</dependency>
6.5 依赖范围
依赖的jar默认情况可以在任何地方使用,可以通过scope标签设定其作用范围
作用范围:
- 主程序范围有效(main文件夹范围内)
- 测试程序范围有效(test文件夹范围内)
- 是否参数打包(package指令范围内)
scope | 主代码 | 测试代码 | 打包 | 范例 |
---|---|---|---|---|
compile(默认) | Y | Y | Y | log4j |
test | Y | junit | ||
provided | Y | Y | servlet-api | |
runtime | Y | jdbc |
依赖范围传递性:
- 带有依赖范围的资源在进行传递时,作用范围将受到影响
7.生命周期与插件
7.1 构建声明周期
Maven对项目构建的声明周期划分为3套
- clean:清理工作
- default:核心工作,如编译,测试,打包,部署等
- site:产生报告,发布站点等
1.clean生命周期
- pre-clean:执行一些需要在clean之前完成的工作
- clean:移除所有上一次构建生成的文件
- post-clean:执行一些需要在clean之后立刻完成的工作
2.default构建生命周期
- validate(校验):
- initialize(初始化):
- generate-sources(生成源代码):
- process-sources(处理源代码):
- generate-resources(生成资源文件):
- process-resources(处理资源文件):
- compile(编译):
- process-classes(处理类文件):
- generate-test-sources(生成测试源代码):
- process-test-sources(处理测试源代码):
- test-compile(编译测试源码):
- process-test-classes(处理测试类文件):
- test(测试):
- prepare-package(准备打包):
- package(打包):
- pre-integration-test(集成测试前):
- integration-test(集成测试):
- post-integration-test(集成测试后):
- verify(验证):
- install(安装):
- deploy(部署):
3.site构建生命周期
- pre-site:执行一些需要在生成站点文档之前完成的工作
- site:生成项目的站点文档
- post-site:执行一些需要在生成站点文档之后完成的工作,并且为部署做准备
- site-deploy:将生成的站点文档部署到特定服务器上
7.2 插件
插件与生命周期内的阶段绑定,在执行到对应生命周期时执行对应的插件功能
默认maven在各个生命周期上绑定有预设的功能
通过插件可以自定义其他功能
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-source-plugin</artifactId>
<version>2.2.1</version>
<executions>
<execution>
<goals>
<goal>jar</goal>
</goals>
<phase>generate-test-resources</phase>
</execution>
</executions>
</plugin>
</plugins>
</build>