Maven简介
Maven是什么
- 传统项目管理状态分析
- jar包不统一,jar包不兼容
- 工程升级维护过程操作繁琐
- Maven的本质是一个项目管理工具,将项目开发和管理过程抽象成一个项目对象模型(POM)
- POM(Project Object Model):项目对象模型
- Maven必须有pom.xml文件
Maven的作用
- 项目构建:提供标准的、跨平台的自动化项目构建方式
- 依赖管理:方便快捷的管理项目依赖的资源(jar包),避免资源间的版本冲突问题
- 统一开发结构:提供标准的、统一的项目结构
Maven下载
Maven属于绿色版软件,解压即安装
maven官网:https://maven.apache.org/
下载地址:https://maven.apache.org/download.cgi
Maven环境变量配置
依赖Java,需要配置JAVA_HOME
设置MAVEN自身的运行环境,需要配置MAVEN HOME
测试环境配置结果
MVN
Maven基础概念
仓库
- 仓库:用于存储资源,包含各种jar包
- 在maven运行过程中,所有的命令执行都是基于插件和依赖完成的,这些都称为maven的资源,资源的来源是maven社区中央库,在使用过程中可以通过远程库代理,获取资源并存储在本地库。~
- 仓库分类:
- 本地仓库:自己电脑上存储资源的仓库,连接远程仓库获取资源
- 远程仓库:非本机电脑上的仓库,为本地仓库提供资源
- 中央仓库:Maven团队维护,存储所有资源的仓库
- 私服:部门/公司范围内存储资源的仓库,从中央仓库获取资源
- 私服的作用:
- 保存具有版权的资源,包含购买或自主研发的jar
- 中央仓库中的iar都是开源的,不能存储具有版权的资源
- 一定范围内共享资源,仅对内部开放,不对外共享
- 保存具有版权的资源,包含购买或自主研发的jar
坐标
-
什么是坐标?
-
Maven中的坐标用于描述仓库中资源的位置
Maven仓库: https://repo1.maven.org/maven2/
Maven坐标主要组成
-
有
三个主要组成
groupld:定义当前Maven:项目隶属 组织名称(通常是 域名反写,例如:org.mybatis).
artifactld:定义当前Maven 项目 名称(通常是 模块名称,例如CRM、SMS)
version:定义当前模块、项目 版本号
packaging:定义该项目的打包方式
Maven:坐标的作用
-
使用唯一标识,唯一性定位资源位置,通过该标识可以将资源的识别与下载工作交由机器完成
Maven坐标仓库: https://mvnrepository.com/( 很有用)
配置
本地仓库配置
- Maven启动后,会自动保存下载的资源到本地仓库
- 默认位置
<localRepository>$(user.home)/.m2/repository</localRepository>
当前目录位置为登录用户名所在目录下的.m2文件夹中 - 自定义位置
<localRepository>D:\maven\repository</localRepository>
当前目录位置为D:maven\repository文件夹中
- 默认位置
- 配置过程
在D:\maven中创建repository(本地库文件夹)
远程仓库配置
- Maven默认连接的仓库位置(下载位置)
26 <repositories> 27 <repository> 28 <id>central</id> 29 <name>Central Repository</name> 30 <url>https://repo.maven.apache.org/maven2</url> 31 <layout>default</layout> 32 <snapshots> 33 <enabled>false</enabled> 34 </snapshots> 35 </repository> 36 </repositories>
- 镜像仓库配置
在settting文件中配置阿里云镜像仓库146 <mirrors> 147 <!--配置具体的仓库的下载镜像--> 148 <mirror> 149 <!--此镜像的唯一标识符,用来区分不同的mirror元素--> 150 <id>nexus-aliyun</id> 151 <!--对哪种仓库进行镜像,简单说就是替代哪个仓库 --> 152 <mirrorOf>central</mirrorOf> 153 <!--镜像名称--> 154 <name>Nexus aliyun</name> 155 <I--镜像URL --> 156 <url>http://maven.aliyun.com/nexus/content/groups/public</url> 157 </mirror> 158 </mirrors>
- 全局setting与用户setting区别
全局settting定义了当前计算器中Maven的公共配置
用户settting定义了当前用户的配置(会覆盖全局setting)(将setting配置文件放在repository仓库同层目录下)
资源的内容
maven项目
pom.xml配置文件
- 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/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.itheima</groupId> <artifactId>project-java</artifactId> <version>1.0-SNAPSHOT</version> <dependencies> </dependencies> </project>
- java/web工程的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/maven-v4_0_0.xsd"> <!-- 指定pom模型版本 --> <modelVersion>4.0.0</modelVersion> <!-- 组织ID --> <groupId>com.itheima</groupId> <!-- 项目ID --> <artifactId>project-java</artifactId> <!-- 版本号:release,snapshot(开发版) --> <version>1.0-SNAPSHOT</version> <!--打包方式,web工程打包为war,java工程打包为jar--> <packaging>war/jar</packaging> <!--java--> <!-- 当前工程所有依赖资源 --> <dependencies> <!-- 具体依赖 --> <dependency> <!-- maven坐标 --> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> </dependency> </dependencies> <!--web--> <!--构建--> <build> <!--设置插件--> <plugins> <!--具体的插件配置--> <plugin> <groupId>org.apache.tomcat.maven</groupId> <artifactId>tomcat7-maven-plugin</artifactId> <version>2.1</version> <configuration> <!--端口号--> <port>80</port> <!--路径--> <path>/</path> </configuration> </plugin> </plugins> </build> </project>
*使用命令行手工制作maven项目
手动创建项目文件夹
- Maven工程目录结构
pom.xml文件需在src同层目录下创建
Maven项目构建命令
- Maven构建命令使用mvn开头,后面添加功能参数,可以一次执行多个命令,使用空格分隔
- 使用命令行,在项目目录中执行一下命令
mvn compile #编译 #生成target目录,存放生成文件(源java)
mvn clean #清理 #删除target目录
mvn test #测试 #会在target目录中生成测试报告(testjava)
mvn package #打包 # 只打包源程序
mvn install #安装到本地仓库 #将打包的jar包安装到本地
- 第一次执行会下载需要的插件,
使用命令创建工程
- 创建工程命令
mvn archetype:generate
-DgroupId=(project-packaging}
-DartifactId={project-name}
-DarchetypeArtifactId=maven-archetype-quickstart
-DinteractiveMode=false
- 创建java工程
mvn archetype:generate -DgroupId=com.itheima -DartifactId=java-project -DarchetypeArtifactId=maven-archetype-quickstart -Dversion=0.0.1-snapshot -DinteractiveMode=false
- 创建web工程
mvn archetype:generate -DgroupId=com.itheima -DartifactId=web-project -DarchetypeArtifactId=maven-archetype-webapp -Dversion=0.0.1-snapshot -DinteractiveMode=false
IDEA生成Maven项目
初始化Maven设置
- 单击【Configure】→【Project Defaults】→【Settings】进入设置Maven界面
初始化JDK设置
- (1)【Configure】→【Project Defaults】→【Project Structure】进入JDK设置页
- (2)在界面左侧选择【Project Settings】一【Project】选项
创建Maven项目
-
创建空原型项目
-
使用原型创建Java、web项目
-
修改目录结构
/或 /
-
maven项目管理
- 自定义Maven命令操作
web工程
配置插件
- Tomcat7运行插件
<!--构建-->
<build>
<!--设置插件-->
<plugins>
<!--具体的插件配置-->
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.1</version>
<configuration>
<!--端口号-->
<port>80</port>
<!--路径-->
<path>/</path>
</configuration>
</plugin>
</plugins>
</build>
运行
- 编写好index页面
配置好pom.xml的tomcat插件,
刷新、双击run可以运行
点开网址就能打开web页面
- 可以自定义一个启动
小结
Maven环境配置
Maven项目创建
Maven命令执行
依赖管理
依赖配置
- 依赖指当前项目运行所需的jr,一个项目可以设置多个依赖
- 格式:
<!--设置当前项目所依赖的所有jar-->
<dependencies>
<!一设置具体的依赖-一>
<dependency>
<!一依赖所属群组id-->
<groupId>junit</groupId>
<!一依赖所属项目1d-->
<artifactId>junit</artifactId>
<!一依赖版本号-->
<version>4.12</version>
</dependency>
</dependencies>
依赖传递
- 依赖具有传递性
直接依赖:在当前项目中通过依赖配置建立的依赖关系
间接依赖:被依赖的资源如果依赖其他资源,当前项目间接依赖其他资源
- 依赖传递冲突问题
路径优先:当依赖中出现相同的资源时,层级越深,优先级越低,层级越浅,优先级越高
声明优先:当资源在相同层级被依赖时,配置顺序靠前的覆盖配置顺序靠后的
特殊优先:当同级配置了相同资源的不同版本,后配置的覆盖先配置的
可选依赖
可选依赖指:符外隐藏当前所依赖的资源一一不透明(不让依赖自己的知道自己依赖的资源有什么)
<optional>true</optional>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<optional>true</optional>
</dependency>
排除依赖
排除依赖指主动断开依赖的资源,被排除的资源无需指定版本一一不需要(依赖别人资源时,不要其依赖的某一资源)
<dependency>
<groupIdjunit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<!-- 不要依赖资源junit依赖的hamcrest-core -->
<exclusions>
<exclusion>
<groupId>org.hamcrest</groupId>
<artifactId>hamcrest-core</artifactId>
</exclusion>
</exclusions>
</dependency>
依赖范围
- 依赖的jar默认情况可以在任何地方使用,可以通过scope标签设定其作用范围
- 作用范围
- 主程序范围有效(main文件夹范围内)
- 测试程序范围有效(test文件夹范围内)
- 是否参与打包(package:指令范围内)
- 在maven项目管理中可以看范围,默认是compile
依赖范围传递性
带有依赖范围的资源在进行传递时,作用范围将受到影响
生命周期与插件
项目构建生命周期
- Maven构建生命周期描述的是一次构建过程经历经历了多少个事件
- Maven对项目构建的生命周期划分为3套
- clean:清理工作
- default:核心工作,例如编译,测试,打包,部署等
- site:产生报告,发布站点等
clean生命周期
- pre-clean
执行一些需要在clean之前完成的工作 - clean
移除所有上一次构建生成的文件 - post-clean
执行一些需要在clean之后立刻完成的工作
default构建生命周期
生命周期(从上往下顺序进行) | 所做的事 |
---|---|
validate(校验) | 校验项目是否正确并且所有必要的信息可以完成项目的构建过程 |
initialize(初始化) | 初始化构建状态,比如设置属性值 |
generate-sources(生成源代码) | 生成包含在编译阶段中的任何源代码。 |
process-sources(处理源代码) | 处理源代码,比如说,过滤任意值。 |
generate-resources(生成资源文件) | 生成将会包含在项目包中的资源文件。 |
process-resdorces(处理资源文件) | 复制和处理资源到目标目录,为打包,阶段最好准备。 |
compile(编译) | 编泽项目的源代码。 |
process-classes(处理类文件) | 处理编译生成的文件,比如说对java class文件做字节码改善优化. |
generate-test-sources(生成测试源代码) | 生成泡含在编泽阶段中的任何测试源代码】 |
process-test-sources(处理测试源代码) | 处理测试源代码,比如说,过滤任意值。 |
generate-test-resources(生成测试资源文件) | 为测试创建资源文件, |
process-test-resources(处理测试资源文件) | 复制和处理测试资源到目标目录。 |
test-compile(编泽测试源码) | 编泽测试源代码到测试目标目录, |
process-test-classes(处理测试类文件) | 处理测试源码编泽生成的文件。 |
test(测试) | 使用合适的单元测试框架运行测试(junit是其中之一)。 |
prepare-package(准备打包) | 在实际打包之前,执行任何的必要的操作为打包做准备。 |
package(打包) | 将编译后的代码打包成可分发格式的文件,比如JAR、WAR或者EAR文件。 |
pre-integration-test(集成测试前) | 在执行集成测试前进行必要的动作。比如说,搭建需要的环境, |
integration-test(集成测试) | 处理和部署项目到可以运行集成测试环境中。 |
post-integration-test(集成测试后) | 在执行集成测试完成后进行必要的动作。比如说,清理集成测试环境 |
verify(验证) | 运行任意的检查来验证项目包有效且达到质量标准 |
install(安装) | 安装项目包到本地仓库,这样项目包可以用作其他本地项目的依赖。 |
deploy(部曙) | 将最终的项目包复制到远程仓库中与其他开发者和项目共享。 |
site构建生命周期
- pre-site:执行一些需要在生成站点文档之前完成的工作
- site:生成项目的站点文档
- post-site:执行一些需要在生成站点文档之后完成的工作,并且为部署做准备
- site-deploy:将生成的站点文档部署到特定的服务器上
插件
- 插件与生命周期内的阶段绑定,在执行到对应生命周期时执行对应的插件功能
- 默认maven在各个生命周期上绑定有预设的功能
- 通过插件可以自定义其他功能
- maven在pom文件中可以管理当前项目的基本信息,引入当前项目使用的所有资源,其中包含插件资源;
- 例如,打包时,可以利用插件指定main方法所在的类路径,这样jar包就可以运行;
需要在pom文件中的<build><plugins></plugins></build>
main方法插件
我们如果没添加main方法插件,直接运行mvn package命令生成的jar包,会出现以下的错误,错误的原因是没有指定入口方法main方法。
main方法插件的作用:在打包、安装时生成的jar文件中,指定配置文件指向可以运行的入口类cn.edu.scnu.App;
在pom.xml中添加插件资源内容。
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<mainClass>cn.edu.scnu.App</mainClass> <!-- 此处为主入口-->
</manifest>
</archive>
</configuration>
</plugin>
</plugins>
</build>
重新打包
D:\java\maven-test\Maven-Test01>mvn clean package
再次执行出现结果:
打上插件(可以指定在某个生命周期执行某事)
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-source-plugin</artifactId>
<version>2.2.1</version>
<executions>
<execution>
<goals>
<goal>jar/test</goal>
</goals>
<!--阶段-->
<phase>generate-test-resources</phase>
</execution>
</executions>
</plugin>
</plugins>
</build>
- 打上生成源码包插件(可以指定在generate-test-resources生命周期执行对java/test的源代码打源码包)
执行
- 插件的执行时期是generate-test-resources(生成测试资源文件),在执行test时会经过这个时期,将java的源代码打成源码包
- 执行install时会默认生成一个jar包,而插件会在执行时期将test的源代码打成源码包
- 也可以同时打java和test的源码包