我们为什么要学这个技术?
每次Javaweb开发要手动导入大量的jar包,非常麻烦
如何让一个东西帮我自动导入和配置这些jar包,由此maven工具诞生了。
Maven项目架构管理工具
maven的核心思想:约定大于配置
有约束不要去违反
Maven会规定好你该如何去编写我们的java代码,必须要按照这个规范来。
下载安装Maven
下载后解压即可
配置环境变量
M2-HOME maven下的bin目录位置
MAVEN_HOME maven的目录位置
在系统的path中配置%MAVEN_HOME%\bin
配置完在DOS窗口里输入mvn -version 检查是否安装成功
如果显示不存在命令,请将path中配置更改为 maven下的bin目录位置
建议将conf中的settings.xml文件中的下载镜像修改成阿里云下载
<mirror>
<id>nexus-aliyun</id>
<mirrorOf>*</mirrorOf>
<name>Nexus aliyun</name>
<url>http://maven.aliyun.com/nexus/content/groups/public</url>
</mirror>
建立本地仓库localRepository
新建文件夹maven-repo
将文件夹位置在settings.xml中localRepository处引入
在IDEA中使用Maven
新建一个模板maven项目
等待项目初始化导入完毕(有时需要点击右下角Enable-Auto-import才会开始导入)
观察创建成功后在Maven仓库的空文件夹下多出了什么东西?
IDEA中的Maven设置
Maven项目创建成功后注意看一眼Maven配置
创建模板Maven项目完毕
注意:webapp目录只有在创建web项目时才会有
创建普通Maven项目,不用勾选模板,其他步骤一样
在模板Maven项目中main下创建Java 和resources文件夹(或者用新建文件夹右键标记目录为该类型)
在IDEA中配置Tomcat
1.点击添加配置
2.点击加号创建配置
3.选择本地Tomcat
4.
5.解决警告
为什么会有这个问题:我们访问一个网站,必须要指定一个文件夹的名字
6.点击运行,启动Tomcat
pom文件
pom.xml是maven的核心配置文件
<?xml version="1.0" encoding="UTF-8"?>
<!--maven版本和头文件-->
<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/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<!--自己配置的JAV-->
<groupId>com.zhang</groupId>
<artifactId>javaweb-01-maven</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>war</packaging> <!--项目的两种打包方式:jar包是java应用war包是javaweb应用-->
<name>javaweb-01-maven Maven Webapp</name>
<!-- FIXME change it to the project's website -->
<url>http://www.example.com</url>
<!--配置-->
<properties>
<!--项目的默认构建编码-->
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<!--编译版本-->
<maven.compiler.source>1.7</maven.compiler.source>
<maven.compiler.target>1.7</maven.compiler.target>
</properties>
<!--项目依赖-->
<!--具体依赖的jar包配置文件-->
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
</dependencies>
<!--项目构建用的东西-->
<build>
<finalName>javaweb-01-maven</finalName>
<pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
<plugins>
<plugin>
<artifactId>maven-clean-plugin</artifactId>
<version>3.1.0</version>
</plugin>
<!-- see http://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_war_packaging -->
<plugin>
<artifactId>maven-resources-plugin</artifactId>
<version>3.0.2</version>
</plugin>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.0</version>
</plugin>
<plugin>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.22.1</version>
</plugin>
<plugin>
<artifactId>maven-war-plugin</artifactId>
<version>3.2.2</version>
</plugin>
<plugin>
<artifactId>maven-install-plugin</artifactId>
<version>2.5.2</version>
</plugin>
<plugin>
<artifactId>maven-deploy-plugin</artifactId>
<version>2.8.2</version>
</plugin>
</plugins>
</pluginManagement>
</build>
</project>
可以在pom.xml中导入依赖,maven高级在可以帮你导入这个jar包所依赖的其他jar包。
maven由于约定大于配置,之后可能遇到自己写的配置文件无法被导出或者生效的问题,解决方案:在pom.xml文件中build内配置resoures
<!--在build中配置resources,来防止我们资源导出失败的问题-->
<build>
<resources>
<resource>
<directory>src/main/resources</directory>
<excludes>
<exclude>**/*.properties</exclude>
<exclude>**/*.xml</exclude>
</excludes>
<filtering>false</filtering>
</resource>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
</resources>
</build>
IDEA目录树