插件是可以配置在settings.xml和pom.xml中的

插件目标

  在了解插件和生命周期的绑定关系之前,先来说一下插件目标。在实际项目构建的过程中,需要经历编译、打包等等许许多多的操作,为每个操作都单独定义一个插件是不可取的,因为有很多可以复用的代码。所以一个插件往往有许多个目标,每个目标完成一个具体的操作。比如denpendency:tree中,dependency指的是插件前缀,tree指的就是插件目标。

默认绑定:maven生命周期的阶段与插件的目标是相互绑定的,比如maven-compile-plugin插件默认绑定maven defalut生命周期的compile阶段。

内置绑定(生命周期和插件的绑定关系):

  clean生命周期:

生命周期阶段

插件目标

pre-clean

 

clean

maven-clean-plugin:clean

post-clean

 

 

 

 

  site生命周期:

生命周期阶段

插件目标

pre-site

 

site

maven-site-plugin:site

post-site

 

site-deploy

maven-site-plugin:deploy

 

 

 

 

 

  default生命周期:

生命周期阶段

插件目标

执行任务

process-resources

maven-resources-plugin:resources

复制主资源文件至主输出目录

compile

maven-compiler-plugin:compile

编译主代码至输出目录

process-test-resources

maven-resources-plugin:testResources

复制测试资源文件至测试输出目录

test-compile

maven-compiler-plugin:testCompile

编译测试代码至测试输出目录

test

maven-surefire-plugin:test

执行测试用例

package

maven-jar-plugin:jar

创建项目jar包

install

maven-install-plugin:install

将项目输出构件安装到本地仓库

deploy

maven-deploy-plugin:deploy

将项目输出构件安装到远程仓库

 

 

 

 

 

 

  

 

 



自定义绑定(配置插件和maven生命周期的目标绑定):直接看例子吧~



pom.xml配置:

      

pom 配置多个 maven 地址 pom中定义使用maven-dependency-plugin插件的位置_runtime

执行:

    

pom 配置多个 maven 地址 pom中定义使用maven-dependency-plugin插件的位置_pom 配置多个 maven 地址_02

 输出:

     

pom 配置多个 maven 地址 pom中定义使用maven-dependency-plugin插件的位置_java_03

源码包:

    

pom 配置多个 maven 地址 pom中定义使用maven-dependency-plugin插件的位置_runtime_04

比对:

    

pom 配置多个 maven 地址 pom中定义使用maven-dependency-plugin插件的位置_maven_05

 

 

插件获取来源:

  官网:http://maven.apache.org/plugins/index.html

  1.Apache:https://repo.maven.apache.org/maven2/org/apache/maven/plugins/。一般maven-*-plugin的都是maven官网的plugin,引用插件时可以忽略groupId的书写。

  2.codehaus.org

  3.code.google.com

 插件的使用:

  这里再次强调一下在"maven常用命令"中提到过的"mvn help:describe 参数(如-Dplugin=org.apache.maven.plugins:maven-compiler-plugin:2.1)"。当我们遇到某个不了解的插件,但是想要去使用时,可以借助这个命令来查看。这个命令的原理实际是调取了maven-help-plugin这个描述插件

  命令行调取插件格式:mvn [options] [goal(s)] [phase(s)],其中options可以在命令行中使用mvn -h查看和学习,goals指定插件的目标 phase指定在某个特定的生命周期的某个阶段执行。

 插件仓库和解析机制:

  在settings.xml中配置<pluginRepsitories>元素即可。默认也是会从maven的中央仓库来下载(id=central)

  默认的groupId有两个org.apache.maven.plugin、org.codehaus.mojo,对应<pluginGroups>元素(顾名思义,可以配置多个)。

settings.xml配置:



<pluginGroups>
    <!-- 官方插件,为了确保稳定不支持快照版 -->
    <pluginGroup>org.apache.maven.plugins</pluginGroup>
    <!-- 另一个插件网站,被墙了进不去 -->
    <pluginGroup>org.codehaus.mojo</pluginGroup>
    <!-- 自己的插件地址 -->
   <pluginGroup>com.your.plugins</pluginGroup>
</pluginGroups>



    maven超级pom中默认的插件配置:

pom 配置多个 maven 地址 pom中定义使用maven-dependency-plugin插件的位置_java_06

 

 解析机制:

  groupId:settings.xml => <pluginGroups>

  artifactId:pom.xml中某插件的<artifactId>

  1.通过groupId + artifactId定位到元数据关系文件 =>maven-metadata-xxx.xml

  

pom 配置多个 maven 地址 pom中定义使用maven-dependency-plugin插件的位置_runtime_07

    

  2.关系文件中定义了插件的名称、前缀、组件id

  

pom 配置多个 maven 地址 pom中定义使用maven-dependency-plugin插件的位置_测试_08

  3.maven会优先基于默认的groupId归并插件仓库的元数据,并进行查找,找不到就找<pluginGroups>中定义的下一个,都没有就报错。

 自定义插件:(待补充...)

  条件:

    <packaging>元素值必须为:maven-plugin

    <dependency>元素必须依赖maven-plugin-api插件

    必须继承AbatractMojo类并实现execute()

    必须使用@goal注解声明插件的目标

  注解:

    @goal <name>                          唯一必须声明的标注,描述插件的目标名称

    @phase <name>                         执行插件的生命周期

    @requiresDependencyResolution <scope>            运行mojo前必须解析所有指定范围的依赖,compile、test、runtime,默认为runtime

    @requiresProject <true/false>                 是否必须在一个maven项目中运行,默认为true。

    @requireDirectInvocation <true/false>            是否只能使用命令行调用,默认为false

    @requiresOnline <true/false>                  是否必须maven在线,默认false

    @requiresReport <true/false>                 是否要求项目报告已经生成,默认为false  

    @aggregator                           mojo在多模块运行时,是否只在顶层模块运行

    @execute goal = "<goal>"                    运行该目标前,是否先运行另一个mojo目标

    @execute phase = "<phase>"                   运行该目标前,是否先让maven运行一个并行的生命周期,到指定阶段为止

    @execute lifecycle = "<lifecycle>" phase="<phase>"     运行该目标前,让maven先运行一个自定义的生命周期,到指定阶段为止

    @parameter alias = "<aliasName>"               为入参设置别名

    @parameter expression = "${aSystemProperty}"        使用系统参数为入参赋值

    @parameter default-value = "aValue/${anExpression}"     使用固定值或表达式设置一个默认值

    @readonly                             只读参数,无法设置

    @required                             必须参数,没有默认值也不传就会报错

  错误日志:AbstractMojo提供一个getLog()方法,入参支持四种级别的日志方法:debug、info、warn、error。