概念
1.1什么是Maven?
一个对 Maven 比较正式的定义是这么说的:
Maven 是一个项目管理工具,它包含了一个项目对象模 型 (POM:Project Object Model),
一组标准集合,
一个项目生命周期(Project Lifecycle),
一个依赖管 理系统(Dependency Management System),
和用来运行定义在生命周期阶段(phase)中插件(plugin)目标 (goal)的逻辑
1.2 Maven 能解决什么问
能帮你构建工程,管理 jar 包,编译代码,还能帮你自动运行单元测试,打包,生成报表,甚至能帮你部署项目,生成 Web 站 点。
引入jar包
我们需要引用各种 jar 包,尤其是比较大的工程,引用的 jar 包往往有几十个乃至上百个, 每用 到一种 jar 包,都需要手动引入工程目录,而且经常遇到各种让人抓狂的 jar 包冲突,版本冲突。编译代码
我们辛辛苦苦写好了 Java 文件,可是只懂 0 和 1 的白痴电脑却完全读不懂,需要将它编译成二 进制字节码。好歹现在这项工作可以由各种集成开发工具帮我们完成,Eclipse、IDEA 等都可以将代 码即时编译单元测试
世界上没有不存在 bug 的代码,计算机喜欢 bug 就和人们总是喜欢美女帅哥一样。为了追求美为 了减少 bug,因此写完了代码,我们还要写一些单元测试,然后一个个的运行来检验代码质量。生成、部署
再优雅的代码也是要出来卖的。我们后面还需要把代码与各种配置文件、资源整合到一起,定型 打包,如果是 web项目,还需要将之发布到服务器,供人蹂躏。
1.3Maven的依赖管理
传统的 WEB 项目中,我们必须将工程所依赖的 jar 包复制到工程中,导致了工程的变得很大。那么 maven 工程是如何使得工程变得很少呢?
通过分析发现:
maven 工程中不直接将 jar 包导入到工程中,而是通过在 pom.xml 文件中添加所需 jar 包的坐标,这样就很好的避免了 jar 直接引入进来,
在需要用到 jar 包的时候,只要查找 pom.xml 文 件,
再通过 pom.xml 文件中的坐标,
到一个专门用于”存放 jar 包的仓库”(maven 仓库)中根据坐标
从 而找到这些 jar 包,再把这些 jar 包拿去运行。
那么问题来了
第一:”存放 jar 包的仓库”长什么样?
第二:通过读取 pom.xml 文件中的坐标,再到仓库中找到 jar 包,会不会很慢?从而导致这种方式 不可行!
第一个问题:
存放 jar 包的仓库长什么样,
这一点我们后期会分析仓库的分类,
也会带大家去看我们 的本地的仓库长什么样。
第二个问题:
通过 pom.xml 文件配置要引入的 jar 包的坐标,
再读取坐标并到仓库中加载 jar 包,
这 样我们就可以直接使用 jar 包了,
为了解决这个过程中速度慢的问题,
maven 中也有索引的概念,
通 过建立索引,可以大大提高加载 jar 包的速度,
使得我们认为 jar 包基本跟放在本地的工程文件中再 读取出来的速度是一样的。
这个过程就好比我们查阅字典时,
为了能够加快查找到内容,
书前面的 目录就好比是索引,
有了这个目录我们就可以方便找到内容了,
一样的在 maven 仓库中有了索引我 们就可以认为可以快速找到 jar 包
1.4 项目的一键构建
我们的项目,往往都要经历编译、测试、运行、打包、安装 ,部署等一系列过程。
什么是构建?
指的是项目从编译、测试、运行、打包、安装 ,部署整个过程都交给 maven 进行管理,这个 过程称为构建。
一键构建 指的是整个构建过程,使用 maven 一个命令可以轻松完成整个工作。
Maven 规范化构建流程如下:
1.6概念模型
Maven安装
请自行百度,上面有很多详细的教程
Maven仓库
2.1 Maven 仓库的分类
2.2 Maven 工程的认识
Maven 工程的目录结构
作为一个 maven 工程,它的 src目录和 pom.xml 是必备的。 进入 src目录后,我们发现它里面的目录结构如下:
src/main/java —— 存放项目的.
java 文件 src/main/resources —— 存放项目资源文件,如 spring, hibernate 配置文件
src/test/java —— 存放所有单元测试.java 文件,如 JUnit 测试类
src/test/resources —— 测试资源文件
target —— 项目输出位置,编译后的class 文件会输出到此目录
pom.xml——maven 项目核心配置文件
注意:如果是普通的 java 项目,那么就没有webapp 目录。
2.3 Maven 工程的运行
CMD进入 maven 工程目录(当前目录有 pom.xml 文件),运行 tomcat:run 命令。
Maven 常用命令
我们可以在cmd 中通过一系列的 maven 命令来对我们的 maven-helloworld 工程进行编译、测试、运 行、打包、安装、部署
3.1 compile
compile 是 maven 工程的编译命令,作用是将 src/main/java 下的文件编译为 class 文件输出到 target 目录下。
1. cmd 进入命令状态,执行mvn compile
2. 查看 target 目录,看见class 文件已生成,编译完成。
3.2 test
test 是 maven 工程的测试命令 mvn test,会执行src/test/java下的单元测试类。
3.3 clean
clean 是 maven 工程的清理命令,执行 clean 会删除 target 目录及内容。
3.4 package
package 是 maven 工程的打包命令,对于 java 工程执行 package 打成 jar 包,对于web 工程打成war 包。
3.5 install
install 是 maven 工程的安装命令,执行 install 将 maven 打成 jar 包或 war 包发布到本地仓库。 从运行结果中,可以看出: 当后面的命令执行时,前面的操作过程也都会自动执.
3.6 Maven 指令的生命周期
maven 对项目构建过程分为三套相互独立的生命周期,请注意这里说的是“三套”,而且“相互独立”, 这三套生命周期分别是:
Clean Lifecycle 在进行真正的构建之前进行一些清理工作。
Default Lifecycle 构建的核心部分,编译,测试,打包,部署等等。
Site Lifecycle 生成项目报告,站点,发布站点
3.7概念模型
Maven 包含了一个项目对象模型 (Project Object Model),一组标准集合,一个项目生命周期(Project Lifecycle),一个依赖管理系统(Dependency Management System),和用来运行定义在生命周期阶段 (phase)中插件(plugin)目标(goal)的逻辑。
项目对象模型 (Project Object Model) 一个 maven 工程都有一个 pom.xml 文件,通过 pom.xml 文件定义项目的坐标、项目依赖、项目信息、 插件目标等。
依赖管理系统(Dependency Management System) 通过 maven 的依赖管理对项目所依赖的 jar 包进行统一管理。 比如:项目依赖 junit4.9,通过在 pom.xml 中定义 junit4.9 的依赖即使用 junit4.9,如下所示是 junit4.9 的依赖定义:
1 | <!-- 依赖关系 --> |
- 一个项目生命周期(Project Lifecycle) 使用 maven 完成项目的构建,项目构建包括:清理、编译、测试、部署等过程,maven 将这些 过程规范为一个生命周期,如下所示是生命周期的各各阶段:
maven 通过执行一些简单命令即可实现上边生命周期的各各过程,比如执行 mvn compile 执行编译、 执行 mvn clean 执行清理。
一组标准集合 maven将整个项目管理过程定义一组标准,比如:通过 maven 构建工程有标准的目录结构,有 标准的生命周期阶段、依赖管理有标准的坐标定义等。
插件(plugin)目标(goal) maven 管理项目生命周期过程都是基于插件完成的。
idea 开发 maven 项目
4.1 idea 的 maven 配置
- 打开File的Settings 配置 maven
依据图片指示,选择本地 maven 安装目录,指定 maven 安装目录下conf文件夹中 settings 配置文件。
idea 中创建一个 maven 的 web 工程
选择 idea提供好的 maven 的web 工程模
点击 Next填写项目信息
点击 Next,此处不做改动
点击 Next选择项目所在目录
点击 Finish后开始创建工程,耐心等待,直到出现如下界面
手动添加 src/main/java 目录,如下图右键 main 文件夹选择New选择Directory
创建一个新的文件夹命名为 java
创建一个Servlet
要解决问题,就是要将 servlet-api-xxx.jar 包放进来,作为 maven 工程应当添加 servlet的坐标,从而 导入它的 jar在 pom.xml文件添加坐标
直接打开 hello_maven 工程的 pom.xml 文件,再添加坐标
添加 jar 包的坐标时,还可以指定这个 jar 包将来的作用范围。 每个 maven 工程都需要定义本工程的坐标,坐标是 maven 对 jar 包的身份定义,比如:入门程序的 坐标定义如下:
1 | <!--项目名称,定义为组织名+项目名,类似包名--> |
4.3 坐标的来源方式
添加依赖需要指定依赖 jar 包的坐标,但是很多情况我们是不知道 jar 包的的坐标,可以通过如下方 式查询:
从互联网搜索
http://search.maven.org/ http://mvnrepository.com/
4.4 依赖范围
A 依赖 B,需要在 A 的 pom.xml 文件中添加 B 的坐标,添加坐标时需要指定依赖范围,依赖范围包 括:
compile:
编译范围,指 A在编译时依赖 B,此范围为默认依赖范围。编译范围的依赖会用在 编译、测试、运行,由于运行时需要所以编译范围的依赖会被打包。provided:
provided 依赖只有在当 JDK 或者一个容器已提供该依赖之后才使用, provided 依 赖在编译和测试时需要,在运行时不需要,比如:servlet api 被 tomcat 容器提供。runtime:
runtime 依赖在运行和测试系统的时候需要,但在编译的时候不需要。比如:jdbc 的驱动包。由于运行时需要所以 runtime 范围的依赖会被打包。test:
test 范围依赖 在编译和运行时都不需要,它们只有在测试编译和测试运行阶段可用, 比如:junit。由于运行时不需要所以test范围依赖不会被打包。system:
system 范围依赖与 provided 类似,但是你必须显式的提供一个对于本地系统中 JAR 文件的路径,需要指定 systemPath 磁盘路径,system依赖不推荐使用。
在 maven-web 工程中测试各各 scop。
测试总结:
- 默认引入 的 jar 包 ——- compile 【默认范围 可以不写】(编译、测试、运行 都有效 )
- servlet-api 、jsp-api ——- provided (编译、测试 有效, 运行时无效 防止和 tomcat 下 jar 冲突)
- jdbc 驱动 jar 包 —- runtime (测试、运行 有效 )
- junit —– test (测试有效) 依赖范围由强到弱的顺序是:compile>provided>runtime>test
4.5 项目中添加的坐标
4.6设置 jdk 编译版本
使用 jdk1.8,需要设置编译版本为 1.8,这里需要使用 maven 的插件来设置: 在 pom.xml 中加入:
1 | <build> |
编写运行
编写
编写 servlet
编写jsp
xml配置Servlet配置Servlet
配置 tomcat 启动
然后运行tomcat
1、maven 仓库的类型有哪些?
2、maven 工程查找仓库的流程是什么?
3、本地仓库如何配置
5.2 常用的 maven 命令
常用 的 maven 命令包括:
compile:编译
clean:清理
test:测试
package:打包
install:安装
5.3 坐标定义
在 pom.xml 中定义坐标,内容包括:groupId、artifactId、version,详细内容如下:
1 | <!--项目名称,定义为组织名+项目名,类似包名--> |
5.4 pom 基本配置
pom.xml 是 Maven 项目的核心配置文件,位于每个工程的根目录,基本配置如下:
1 | <project > :文件的根节点 . |