Maven之pom.xml文件中的Build配置解析

目录
  • 前言
  • 正文
    • mave的相关插件
    • pom.xml中的build标签
      • 1. pom.xml中的两种build
      • 2. Profile Build和Project Build的共有元素
      • 3. Project Build特有的<…Directory>
      • 4. Project Build特有的
    • Maven常用配置
      • pom.xml基础配置
      • 插件配置
      • 编译插件
      • 测试插件
      • 测试报告插件
      • eclipse插件
      • war包插件
      • tomcat插件
      • 插件命令
  • 总结

前言

在日常的开发中,我们经常使用maven来管理和构建我们的项目,即使现在使用了各种springboot等方便快捷的框架,jar包的引入也是通过maven来进行的,因此有必要了解pom.xml文件中的没一项配置.

正文

mave的相关插件

首先,关于maven我们要有一定的认识:

  • maven能帮我们构建工程,管理jar包,编译代码,还能帮我们自动运行单元测试,生成报表,甚至部署项目.
  • 使用maven构建的项目均可以直接使用maven build完成项目的编译测试打包,无需额外的配置.
  • maven是通过pom.xml来执行任务的.其中的build标签描述了如何来编译打包项目,而具体的编译和打包工作是通过build中配置的plugin来完成的.

默认情况下,maven会绑定一下几个插件来完成基本操作

plugin funcation life cycle phase
maven-clean-plugin 清理上一次执行创建的目标文件 clean
maven-resources-plugin 处理源资源文件和测试资源文件 resources;testResources
maven-compiler-plugin 编译源文件和测试源文件 compile,testCompile
maven-surefire-plugin 执行测试文件 test
maven-jar-plugin 创建jar jar
maven-install-plugin 安装jar,将创建生成的jar拷贝到.m2/repository下面 install
maven-deploy-plugin 发布jar deploy

在没有配置的情况下,执行maven clean install时,maven会调用默认的plugin来完成编译打包操作,具体会执行以下plugin:

maven-clean-plugin:2.5:clean (default-clean)
maven-resources-plugin:2.6:resources (default-resources)
maven-compiler-plugin:3.1:compile (default-compile)
maven-resources-plugin:2.6:testResources (default-testResources)
maven-compiler-plugin:3.1:testCompile (default-testCompile)
maven-surefire-plugin:2.12.4:test (default-test)
maven-jar-plugin:2.4:jar (default-jar)
maven-install-plugin:2.4:install (default-install)

如果有需要可以针对各个plugin进行特殊的配置,需要在pom.xml文件中的标签中显示指定plugin和对应的属性配置.

在后面会有对每一个plugin配置的实例来供参考

pom.xml中的build标签

在Maven的pom.xml文件中,Build相关的配置包含两个部分:一个是,另一个是,这里只介绍.

1. pom.xml中的两种build

在Maven的pom.xml文件中,存在如下两种<build>:

<project>
    <build>...</build>

    <profiles>
     <profile>
            <build>...</build>
        </profile>
    </profiles>
</project>    

说明: 第一种被称为Project Build,即是<project>的直接子元素.另一种<build>被称为Profile Build,即是<profile>的直接子元素.

Profile Build包含了基本的build元素,而Project Build还包含两个特殊的元素,即各种和.

2. Profile Build和Project Build的共有元素

共用的基本build元素

<build>
    <defaultGoal>install</defaultGoal>
    <directory>${basedir}</directory>
    <finalName>${artifactId}-${version}</finalName>
</build>
  • defaultGoal: 执行构建时默认的goal或phase,如jar或者package等
  • directory: 构建的结果所在的路径,默认为${basedir}/target目录
  • finalName: 构建的最终结果的名字,该名字可能在其他plugin中被改变

资源往往不是代码,无需编译,而是一些properties或XML配置文件,构建过程往往会将资源文件从源路径复制到指定的目标路径.

给出各个资源在Maven项目中的具体路径.示例如下:

说明:

  • resource:build过程中涉及的资源文件
  • targetPath:资源文件的目标路径
  • filtering:构建过程中是否对资源进行过滤,默认false
  • directory:资源文件的路径,默认位于${basedir}/src/main/resources目录下
  • includes:一组文件名的匹配模式,被匹配的资源文件将被构建过程处理
  • excludes:一组文件名的匹配模式,被匹配的资源文件将被构建过程忽略,同时被includes和excludes匹配的资源文件,将被忽略.
  • filters:给出对资源文件进行过滤的属性文件的路径,默认位于${basedir}/src/main/filters/目录下.属性文件中定义若干键值对.在构建过程中,对于资源文件中出现的变量(键),将使用属性文件中该键对应的值替换.
  • testResources:test过程中涉及的文件,默认位于${basedir}/src/test/resources/目录下,这里的资源文件不会被构建到目标构建中.

给出构建过程中所用到的插件.

说明:

  • extensions:是否加载该插件的扩展,默认false
  • inherited:该插件的configuration中的配置是否可以被继承,默认true
  • configuration:该插件所需要的特殊配置,在父子项目之间可以进行覆盖或者合并
  • dependencies:该插件所特有的依赖类库
  • executions:该插件的某个goal(一个插件可能包含多个goal)的执行方式.一个execution有如下配置:
  • id:唯一标识
  • goals:要执行插件的goal,可以有多个,如<goal>run</goal>
  • phase:插件的goal要嵌入到Maven的phase中执行,如verify
  • inherited:该execution是否可以被子项目继承
  • configuration:该execution的其他配置参数

在中,与并列,两者之间的关系类似于与之间的关系.中也配置,其配置参数与中的完全一致.只是,往往出现在父项目中,其中配置的往往通用于子项目.

子项目只要在中声明该插件,该插件的具体配置参数则继承自父项目中对该插件的配置,从而避免了在子项目中重复配置.

3. Project Build特有的<…Directory>

往往配置在父项目中,供所有父子项目使用.使用如下:

目录可以使用绝对路径,如果使用相对路径,则所有的相对路径都是在${basedir}目录下.

4. Project Build特有的

是执行构建过程中可能用到的其他工具,在执行构建的过程中被加入到classpath中.也可以通过激活构建插件,从而改变构建的过程.具体使用如下:

Maven默认的输入和输出目录

在构建Maven项目的时候,如果没有进行特殊配置,Maven会按照标准的目录结构查找和处理各种类型文件.

  • src/main/java和src/test/java

这两个目录中的所有*.java文件会分别在comile和test-comiple阶段被编译,编译结果分别被放到了target/classes和target/test-classes目录中,但是这两个目录中的其他文件会被忽略掉.

  • src/main/resources和src/text/resources

这两个目录中的文件也会分别被复制到target/classes和target/test-classes目录中.

当项目是web项目时,会在target目录下生成myProject目录,myProject是你的项目名

  • src/main/webapps

这个目录中的文件会被复制到target/myProject目录中.

  • target/classes

默认会把这个目录中的所有内容复制到target/myProject/WEB-INF/calssess中

  • Dependency

默认会将项目的依赖复制到target/myProject/WEB-INF/lib

Maven常用配置

pom.xml基础配置

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <spring.framework.version>3.0.5.RELEASE</spring.framework.version>
        <cxf.version>2.3.2</cxf.version>
        <tiles.version>2.2.2</tiles.version>
    </properties>

我需要让整个项目统一字符集编码,就需要设定**<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>**;

如果我需要让spring统一版本号,可以设置这么个变量**<spring.framework.version>3.0.5.RELEASE</spring.framework.version>**,

当然,maven不会那么乖乖的自动识别这些配置。

当然,**<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>**默认还是可以识别的!

插件配置

<plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-resources-plugin</artifactId>
        <version>2.4.3</version>
        <configuration>
            <encoding>${project.build.sourceEncoding}</encoding>
        </configuration>
    </plugin>

xml、properties文件都是资源文件,编码的时候遇到中文总要进行转码!用什么编码?UTF-8,那就记得强制**${project.build.sourceEncoding},虽然<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>**默认可以识别,但是我还是觉得不放心。

编译插件

这个插件就是个默认配置,不过我还是谨慎的配置了jdk编译版本跟字符集设置:

<plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>2.0.2</version>
        <configuration>
            <source>1.6</source>
            <target>1.6</target>
            <encoding>${project.build.sourceEncoding}</encoding>
        </configuration>
    </plugin>
  • <source>1.6</source> :源代码编译版本;
  • <target>1.6</target> :目标平台编译版本;
  • <encoding>${project.build.sourceEncoding}</encoding>:字符集编码

如果你用eclipse建立maven项目时,新建的项目往往JDK版本很低——1.5!怎么办?修改settings.xml文件:

<profile>
        <id>jdk-1.6</id>
        <activation>
            <activeByDefault>true</activeByDefault>
            <jdk>1.6</jdk>
        </activation>
        <properties>
            <maven.compiler.source>1.6</maven.compiler.source>
            <maven.compiler.target>1.6</maven.compiler.target>
            <maven.compiler.compilerVersion>1.6</maven.compiler.compilerVersion>
        </properties>
    </profile>

eclipse会很听话的构建一个JDK1.6版本的maven项目!

测试插件

<plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-surefire-plugin</artifactId>
        <version>2.7.2</version>
        <configuration>
            <parallel>methods</parallel>
            <threadCount>10</threadCount>
            <argLine>-Dfile.encoding=UTF-8</argLine>
            <!-- <skip>true</skip> -->
            <!-- <testFailureIgnore>true</testFailureIgnore> -->
        </configuration>
    </plugin>
  • <parallel>methods</parallel>:方法级并发;
  • <threadCount>10</threadCount>:是线程数,当前是10;
  • <argLine>-Dfile.encoding=UTF-8</argLine>:就是参数命令行,这一行很关键。

测试插件有个小问题,它不依赖项目的字符集设置,它依赖于操作系统。如果你用命令行操作,看中文提示测试结果还好。

  • 但在win+eclipse(UTF-8设置)下,那就是乱码了;
  • <skip>true</skip>是忽略测试;
  • <testFailureIgnore>true</testFailureIgnore>:忽略测试异常;

测试报告插件

要测试,就要有报告,知晓测试覆盖率,这就需要clover:

<plugin>
        <groupId>maven</groupId>
        <artifactId>maven-clover-plugin</artifactId>
        <version>2.4.2</version>
        <configuration>
            <encoding>${project.build.sourceEncoding}</encoding>
        </configuration>
    </plugin>

安全起见,我还是要强制字符集编码设置:

<encoding>${project.build.sourceEncoding}</encoding>

可以使用 mvn cobertura:cobertura 产生测试覆盖率报告!

eclipse插件

在eclipse下进行maven项目开发,还是需要eclipse相应的插件:

<plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-eclipse-plugin</artifactId>
        <version>2.8</version>
        <configuration>
            <wtpmanifest>true</wtpmanifest>
            <wtpapplicationxml>true</wtpapplicationxml>
            <wtpversion>2.0</wtpversion>
            <downloadSources>true</downloadSources>
            <downloadJavadocs>true</downloadJavadocs>
        </configuration>
    </plugin>
  • <wtpmanifest>true</wtpmanifest>:产生manifest文件
  • <wtpapplicationxml>true</wtpapplicationxml>:产生web.xml文件
  • <wtpversion>2.0</wtpversion>:这是eclipse里面的wtp版本
  • <downloadSources>true</downloadSources>:下载源代码
  • <downloadJavadocs>true</downloadJavadocs>:下载源码文档

虽然这么配置了,但是由maven项目转为eclipse的wtp类型的项目时,所产生的文件根本没有实际意义。

web.xml文件的servlet版本很低,也许是我没有配置。对应的xml字符集的头标识也没有。

war包插件

既然是web项目,就需要打war包,那就需要这个插件:

<plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-war-plugin</artifactId>
        <version>2.1.1</version>
        <configuration>
            <encoding>${project.build.sourceEncoding}</encoding>
            <warName>platform</warName>
            <webappDirectory>${project.build.directory}/platform</webappDirectory>
            <warSourceDirectory>WebContent</warSourceDirectory>
        </configuration>
    </plugin>
  • <encoding>${project.build.sourceEncoding}</encoding>强制字符集编码
  • <warName>platform</warName>war包名字——platform.war
  • <webappDirectory>${project.build.directory}/platform</webappDirectory>产生war前,用于存放构建war包的目录——target/platform。
  • <warSourceDirectory>WebContent</warSourceDirectory>:我把web工程搞成了eclipse下的WTP类型。我不喜欢maven产生的webapp目录,更喜欢WebContent!

tomcat插件

我习惯于用tomcat作为JSP容器,对jetty多少有点陌生。不但如此,我还通过在Bamboo中配置命令让这个应用可以在tomcat中定时部署:

<plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>tomcat-maven-plugin</artifactId>
        <configuration>
            <charset>${project.build.sourceEncoding}</charset>
            <url>http://localhost:8080/manager</url>
            <server>tomcat.server</server>
            <path>/platform</path>
            <port>8080</port>
            <warFile>${project.build.directory}/platform.war</warFile>
            <warSourceDirectory>WebContent</warSourceDirectory>
            <uriEncoding>${project.build.sourceEncoding}</uriEncoding>
        </configuration>
    </plugin>
  • <charset>${project.build.sourceEncoding}</charset>:字符集强制编码
  • <url>http://localhost:8080/manager/text</url>:我这里已经使用了Tomcat7,如果是Tomcat6就不需要/text!
  • <server>tomcat.server</server>这是个用户名设置

需要配置maven的settings.xml文件:

<servers>
        <server>
            <id>tomcat.server</id>
            <username>admin</username>
            <password>123456</password>
        </server>
    </servers>

别急,这时候还没完!

在tomcat的tomcat-users.xml中补充相关内容:

<role rolename="manager-gui"/>
    <role rolename="magager-script"/>
    <user username="admin" password="123456" roles="manager-gui,manager-script" />
  • <port>8080</port>:运行时端口
  • <path>/platform</path>:是运行时路径——http://host:port/platform
  • <warFile>${project.build.directory}/platform.war</warFile>:我们以war包方式发布,需要指定war包路径。
  • <warSourceDirectory>WebContent</warSourceDirectory>:同时要指定war包源码路径。这里我使用eclipse的WTP类型工程WebContent目录。
  • <uriEncoding>${project.build.sourceEncoding}</uriEncoding>:强制字符集编码!

插件命令

#Run Tomcat
    mvn tomcat:run
    #Stop Tomcat
    #Deploy Tomcat
    mvn tomcat:deploy
    #Undeploy Tomcat
    mvn tomcat:undeploy
    #Redeploy Tomcat
    mvn tomcat:redeploy

总结

关于maven的使用,是需要经常查阅的,在这里做个记录,工作中有用到的可以来及时补充.

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • Maven配置文件pom.xml详解

    什么是POM? POM是项目对象模型(Project Object Model)的简称,它是Maven项目中的文件,使用XML表示,名称叫做pom.xml.在Maven中,当谈到Project的时候,不仅仅是一堆包含代码的文件.一个Project往往包含一个配置文件,包括了与开发者有关的,缺陷跟踪系统,组织与许可,项目的URL,项目依赖,以及其他.它包含了所有与这个项目相关的东西.事实上,在Maven世界中,project可以什么都没有,甚至没有代码,但是必须包含pom.xml文件. 概览 下面

  • 配置pom.xml用maven打包java工程的方法(推荐)

    最近由于项目需要,研究了一下maven的打包,项目要做到 1,生成3个目录/lib,/conf,/bin目录 2,把所有的jar目录编译.拷贝到/lib目录(包括maven的jar包和lib目录下的jar,以及编译的jar包) 3,把所有的启动脚本从工程根目录拷贝到/bin目录 4,把所有的配置文件从src/main/resources拷贝到/conf 下面是配置的pom.xml,我把相关的配置都加了注释,一看就能明白,把build节点拷贝到你们的项目中,就基本可以用了:) <project x

  • Maven中pom.xml配置文件详细介绍

    setting.xml主要用于配置maven的运行环境等一系列通用的属性,是全局级别的配置文件:而pom.xml主要描述了项目的maven坐标,依赖关系,开发者需要遵循的规则,缺陷管理系统,组织和licenses,以及其他所有的项目相关因素,是项目级别的配置文件. 基础配置 一个典型的pom.xml文件配置如下: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org

  • Maven 命令行打包 和 pom.xml的常用配置详解

    maven 命令行打包 mvn -v, --show-version 现在最新的maven版本是 3.6,我这里用的还是 2017 年下载的 3.1.1 版本(虽然有点过时,但是大版本不变,指令基本一样) mvn -h, --help 使用 help 命令可以看到 maven 命令的帮助文档,下面主要介绍两个常用的指令 -- D 和 P. mvn -D, --define <arg> mvn -DpropertyName=propertyValue clean package 可以用来临时定义

  • Maven之pom.xml文件中的Build配置解析

    目录 前言 正文 mave的相关插件 pom.xml中的build标签 1. pom.xml中的两种build 2. Profile Build和Project Build的共有元素 3. Project Build特有的<-Directory> 4. Project Build特有的 Maven常用配置 pom.xml基础配置 插件配置 编译插件 测试插件 测试报告插件 eclipse插件 war包插件 tomcat插件 插件命令 总结 前言 在日常的开发中,我们经常使用maven来管理和构

  • 基于Maven的pom.xml文件详解

    如下所示: <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 "> <!-- 父项

  • 解决maven没有打包xml文件的问题

    目录 maven没有打包xml文件的问题 maven打包时不打包resources下的xml文件 maven没有打包xml文件的问题 最近使用maven带管理项目,采用SSM的技术栈,在配置好一些配置文件,打包部署到tomcat上,出现没有找到SpringMVC的配置文件,在查看maven打包生成的文件夹中,确实没有看到相应的xml文件. 原来需要在maven的pom.xml文件中加上 <build> <finalName>MobileSchool-chat</finalNa

  • Maven pom.xml文件获取当前时间戳方式

    目录 Maven pom.xml文件获取当前时间戳 问题 解决方案 Maven打包加时间戳方法总结 1.使用maven自带的属性 2.使用buildnubmer-maven-plugin 3.使用build-helper-maven-plugin Maven pom.xml文件获取当前时间戳 今天发布项目到测试环境,发布完成后,一直启动不起来,查看日志发现java.lang.OutOfMemoryError: Java heap space. java.lang.OutOfMemoryError

  • springboot新建项目pom.xml文件第一行报错的解决

    目录 springboot新建项目pom.xml文件第一行报错 新建一个测试项目 下面是文件 解决这个问题只需要 springboot创建过程中pom.xml报错 问题出现原因 解决办法 springboot新建项目pom.xml文件第一行报错 新建一个测试项目 发现创建完毕pom.xml文件报错,提示 Description Resource Path Location Type Unknown pom.xml /demo line 1 Maven Configuration Problem

  • java 中maven pom.xml文件教程详解

    maven pom.xml文件教程详解,具体内容如下所示: <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.x

  • springboot中pom.xml文件注入test测试依赖时报错的解决

    目录 pom.xml文件注入test测试依赖时报错 分析原因 解决方法 springboot中pom.xml之间的依赖 依赖关系 所用到的技术 talkischeap,详见配置文件 pom.xml文件注入test测试依赖时报错 报错:Failed to read artifact descriptor for org.springframework.boot:spring-boot-starter-test:jar:2.0.4.RELEASE 分析原因 有可能是默认版本太高 解决方法 降低版本

  • 解决idea2020.2遇到pom.xml文件报错maven插件tomcat7的问题

    之前百度找答案,指明的是依赖中servlet-api中添加provided 发现自己的依赖中已添加,未找到解决办法. 显示红色报错,阿里云仓库无法下载该文件.报错如下: 找到文件位置,删除maven本地仓库文件 解决办法:指定版本信息2.2 到此这篇关于idea2020.2遇到pom.xml文件报错maven插件tomcat7的问题的文章就介绍到这了,更多相关idea2020.2报错maven插件tomcat7内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

  • IDEA项目的依赖(pom.xml文件)导入问题及解决

    前言 IDEA新建项目和pom.xml文件被修改时,右下角都会出现 Maven projects need to be imported(项目需要导入依赖) 如下,点击 Import Changes导入后,有时会一直处于加载中或导入失败 解决方法 第一种方法: 右击pom.xml文件,选择Maven中的Reimport重新导入项目依赖,一般这种方法都解决不了上面的问题,可直接看下面的方法 第二种方法: 点击 File 选择 Settings- 直接搜索 Maven,在搜索结果中 Maven ho

随机推荐