POM(Project Object Model)(翻译:项目对象模型)->
Maven工程的基本单元,也是Maven的核心。它是一个XML文件,包含项目的基本信息,用于描述项目如何构建、声明项目依赖等。
在执行任务或目标时,Maven会先在当前目录中查找pom.xml文件,然后获取所需的配置信息,再执行目标

pom的元素

  1. dependencies
    在此元素下添加依赖,它可以包含多个依赖
  2. dependency
    与之间有3个标识
    ·groupId:定义隶属的实际项目,坐标元素之一
    ·artifactId:定义项目中的一个模块,坐标元素之一
    ·version:依赖或项目的版本,坐标元素之一
    加上能标识唯一的项目或库

dependency用来声明依赖。如果需要添加依赖,则可以在"“和”"元素之间进行添加。
示例代码:

<dependencies>
<dependency>
<groudId>org.springframework.boot</groudId>
<artifactId>spring-boot-starter-web</artifactId>
<dependency> 
<dependencies>
  1. scope
    如果有一个编译时需要而发布时不需要的JAR包,则可以用scope标签标记该包,并将其值设为provided
    scoped的标签参数

参数

描述

compile

scope的默认值,表示被依赖项目需要参与当前项目的编译、测试、运行阶段,是一个比较强的依赖。打包时也要包含进去

provided

provided表示打包时可以不打包进去,Web Container会提供。该依赖理论上可以参与编译、测试、运行等周期

runtime

表示dependency不作用在编译阶段,但会作用在运行和测试阶段,如JDBC驱动使用运行和测试阶段

system

和provided相似,打在系统中要以外部JAR包的形式提供,Maven不会在reposity中查找它

test

表示dependency作用在测试阶段,不作用在运行阶段。只在测试阶段使用,用于编译和运行测试代码,不随项目发布

  1. properties
    如果要使用自定义的变量,则可以在元素中进行变量的定义,然后在其他节点中引用该变量。它的好处是:在依赖配置时引用变量,可以达到统一版本号的目的
<properties> 
<java.version>1.8</java.version>
<solr.version>8.0.0</solr.version>
</properties>

要使用上面定义的变量,可以通过表达式"${变量名}"来调用:

<dependency>
<groupId>org.apache.solr</groupId>
<artifactId>solr-solrj</artifactId>
<version>${solr.version}</version>
</dependency>
  1. plugin
    在创建SpringBoot项目时,默认提供了spring-boot-maven-plugin插件。它提供打包时需要的信息,将SpringBoot应用打包为可执行的JAR或WAR文件
  2. 完整的pom.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmln="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">
	<!--模型版本,声明项目描述符遵循那个POM模型版本,模型版本很少改变,但它是必不可少的,这是
为了在Maven引入新特性或其他模型变更时,确保稳定性-->
	<modelVersion>4.0.0</modelVersion>
	<!--父项目的坐标,如果项目没规定某个元素的值,那么父项目中的对应值即为项目的默认值,坐标包括
group、artifactId和version-->
	<parent>
		<!--被继承的父项目的唯一标识符-->
		<groupId>org.springframework.boot</groupId>
		<!--被继承的父项目的构件标识符-->
		<artifactId>spring-boot-starter-parent</artifactId>
		<!--被继承的父项目的版本号-->
		<version>2.1.3.RELEASE</version>
		<!--父项目的pom.xml文件的相对路径,相对路径允许一个不同的路径,默认值是../pom.xml 
	Maven在构建当前项目的地方寻找父项目的POM,然后在文件系统的relativePath位置寻找(如果没
	找到,则继续在本地仓库寻找,最后再远程仓库中寻找父项目的POM)-->
		<relativePath/>
	</parent>
	<!--公司或组织的唯一标志(项目的全球唯一标识符),并且配置时生成的路径也是由此生成的,通常使用全限
定的报名区分该项目和其他项目,如com.companyname.project,Maven会将该项目生成的JAR包放在本地路径:
/com/companyname/project-->	 
	<groupId>com.example</groupId>
	<!--项目的唯一ID,一个groupId下面可能有多个项目,靠artifactId来区分-->
	<artifactId>demo</artifactId>
	<!--版本号,格式为主版本.次版本.增量版本-限定版本号-->
	<version>0.0.1-SNAPSHOT</version> 
	<!--项目的名称,用于Maven产生的文档-->
	<name>HelloWord</name>
	<!--项目的详细描述,用于Maven产生的文档。这个元素能够在用HTML格式时使用(例如,CDATA中的文本会被解析器忽略,就可以包含HTML标签)-->
	<description>Demo project for Spring Boot</description>
	<properties>
		<!--项目开发的Java版本号-->
		<java.version>1.8</java.version>
	</properties>
	<!--项目的依赖项,可以通过该元素描述项目相关的所有依赖,它们自动从项目定义的仓库中下载-->
	<dependencies>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-wweb</artifactId>
		</dependency>
		<dependency>
			<groupId>org.projectlombok</group>
			<artifactId>lombok</artifactId>
			<optional>true</optional>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
			<scope>test<scope>
		</dependency>
	</dependencies>
	<!--构建项目(打包生成可执行文件)需要的信息-->
	<build>
		<!--项目使用的插件列表-->
		<plugins> 
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>
</project>