我想很多初学者对上图<project>标签内的:xmlns、xmlns:xsi、schemaLocation都表示不解,那么今天就科普一下它们代表的含义:
xmlns:是xml的命名空间(XML Namespaces),为了避免元素命名冲突。目的是为当前的xml元素命名,以区别其他的同名元素。它有两种命名方式:
- xmlns="namespaceURI" 默认命名空间
- xmlns:namespace-prefix="namespaceURI" 自定义前缀命名空间。
其中,namespaceURI的值指向XSD文件,它是XML结构定义 ( XML Schemas Definition )。XML Schema描述了XML文档的结构。可以用一个指定的XML Schema来验证某个XML文档,以检查该XML文档是否符合其要求。文档设计者可以通过XML Schema指定一个XML文档所允许的结构和内容,并可据此检查一个XML文档是否是有效的。XML Schema本身是一个XML文档,它符合XML语法结构。可以用通用的XML解析器解析它。
一个XML Schema会定义:文档中出现的元素、文档中出现的属性、子元素、子元素的数量、子元素的顺序、元素是否为空、元素和属性的数据类型、元素或属性的默认和固定值。
xmlns="http://maven.apache.org/POM/4.0.0" 不正是默认的命名空间写法吗?
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 不正是自定义前缀的命名空间写法吗?
要使用自定义前缀命名空间的属性,写法必须是:[namespace-prefix]:[namespaceURI中存在的属性]
怎么找到namespaceURI中存在的属性呢?
跳转到了一个xsd文档,这就是xsi的命名空间地址。
我想已经可以明白了。最下边一行的
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"
schemaLocation正是对应xsi的属性。
xsi:schemaLocation属性的值由一个URI引用对组成,两个URI之间以空白符分隔。第一个URI是名称空间的名字,第二个URI给出模式文档的位置,模式处理器将从这个位置读取模式文档,该模式文档的目标名称空间必须与第一个URI相匹配。
到这里,关于xmlns的知识,应该有个大概了解了。下面进入pom.xml的常用元素介绍
- ** pom.xml对于maven是什么作用? **
pom是maven项目的核心管理文件,用于项目描述、组织管理、依赖管理和构建信息的管理。
pom.xml元素详解
- <project></project>:是pom.xml根元素,它包含了pom.xml的一些约束信息。
- <modelVersion></modelVersion>:指定了当前pom.xml版本,目前固定为4.0.0版本。
- <name></name>:项目的描述名。一般产生项目文档时候才会使用。
- <url></url>:项目的地址。
- <description></description>:项目描述。
- <developers></developers>:开发人员的列表。
- <licenses></licenses>:许可证的信息。
- <organization></organization>:组织信息。
- <parent></parent>:用于在子模块中对父模块的一个pom的继承。
坐标元素:
<groupId>反写公司网址+项目名</groupId>:主项目标识,用于显示此项目属于哪个主项目下。
<artifactId>项目名+模块名</artifactId>:此项目属于主项目中的某个模块
<version></version>:当前版本,由版本号-版本类型组成。
例如:
当前项目的版本号0.0.1: 。
第一个0标识大版本号;
第二个0表示分支版本号;
第三个0表示小版本号 。
版本类型:
snapshot:快照
alpha:内部测试
beta:公测
release:稳定
GA:正式发布
<packaging></packaging>:Maven项目打包的方式。默认是jar,还可以打包为war、pom、zip。
依赖列表:
<dependencies>
<dependency>:依赖项
<groupId></groupId>
<artifactId></artifactId>
<version></version>
<scope></scope>:依赖的范围
<type></type>
<optional></optional>:有true、false两个值,默认是false;意思为:设置依赖是否可选。如果为true,则子项目必须显式引入此依赖。
<exclusions>:排除传递依赖的列表
<exclusion></exclusion>:
</exclusions>
</dependency>
</dependencies>
作为父模块时的依赖管理:
- <dependencyManagement></dependencyManagement>:此元素,顾名思义是依赖管理。它也可以在里面声明依赖列表,但是并不会被运行,即不会被引入到实际的依赖中。它主要用于定义在父模块中,供子模块继承用的。举例来讲:我们每开发一个模块都需要junit进行单元测试,如果我们把junit依赖添加在这个标签中,子项目只要继承这个模块,就可以直接使用junit,而不用单独引入了。
为构建行为提供支持:
<build>
<plugins>:插件列表
<plugin>
<groupId></groupId>
<artifactId></artifactId>
<version></version>
</plugin>
</plugins>
</build>
聚合运行多个的maven项目:
<modules>
<model></model>
</modules>