自己动手编写Maven的插件
Maven的插件机制是完全依赖Maven的生命周期的,因此理解生命周期至关重要。本文参考官方文档后使用archetype创建,手动创建太麻烦。
- 创建创建项目
选择maven-archetype-mojo
创建的项目结构如下
这里要理解一个术语:mojo,就是Maven Plain Old Java Object,也就是一个普通的Java类,我们写的插件主要是实现AbstractMojo,而AbstractMojo只有一个public void execute()
我的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">
<modelVersion>4.0.0</modelVersion>
<groupId>net.oseye</groupId>
<artifactId>MvnPluginDemo</artifactId>
<packaging>maven-plugin</packaging>
<version>0.0.1-SNAPSHOT</version>
<name>MvnPluginDemo Maven Mojo</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>org.apache.maven</groupId>
<artifactId>maven-plugin-api</artifactId>
<version>2.0</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
</dependencies>
</project> - 实现execute
我们修改MyMojo.java的代码,来做一个非常简单的插件:package net.oseye; import org.apache.maven.plugin.AbstractMojo;
import org.apache.maven.plugin.MojoExecutionException;
/**
* @goal oseye
*/
public class MyMojo extends AbstractMojo{
public void execute()throws MojoExecutionException
{
getLog().info("这是一个测试插件,goal是oseye");
}
}- getLog()获取的是AbstractMojo内部的log,类型是:org.apache.maven.plugin.logging.Log;至少在Mojo的开发中,不要使用其他的Log基础设施;
- @goal标注,goal是maven里定义任务的最小单元,它可以单独,也可以挂在phase上,一个phase可以挂多个goal;这里是单独的;
- 更多标注信息请参考官方文档;
- 部署&执行
部署插件到本地仓库mvn install
要执行,首先需要在pom.xml或setting.xml中配置
<build>
<plugins>
<plugin>
<groupId>net.oseye</groupId>
<artifactId>MvnPluginDemo</artifactId>
<version>0.0.1-SNAPSHOT</version>
</plugin>
</plugins>
</build>插件执行的命令格式
mvn groupId:artifactId:version:goal
如果是单个的goal可以省略version,执行
mvn net.oseye:MvnPluginDemo:oseye
可以看到输出中有
[INFO] 这是一个测试插件,goal是oseye
- 使用简单命令执行
如果你的artifacitId符合格式 ${prefix}-maven-plugin 或 maven-${prefix}-plugin,可以在你的settings.xml配置文件中加上<pluginGroups>
<pluginGroup>net.oseye</pluginGroup>
</pluginGroups>现在可以这样执行
mvn MvnPluginDemo:oseye
而我的Demo没有按照上述格式配置,更多格式信息请参考官方。
- @execute
这个标注是有三种方式:@execute phase="" lifecycle=""
@execute phase=""
@execute goal=""package net.oseye; import org.apache.maven.plugin.AbstractMojo;
import org.apache.maven.plugin.MojoExecutionException;
/**
* @goal oseye
* @execute phase="compile"
*/
public class MyMojo extends AbstractMojo{
public void execute()throws MojoExecutionException
{
getLog().info("这是一个测试插件,goal是oseye");
}
}这个示例表示当maven执行goal时,先把项目build到compile阶段后在执行goal。
- @phase
这个标注表示默认的phase,如:package net.oseye; import org.apache.maven.plugin.AbstractMojo;
import org.apache.maven.plugin.MojoExecutionException;
/**
* @goal oseye
* @phase validate
*/
public class MyMojo extends AbstractMojo{
public void execute()throws MojoExecutionException
{
getLog().info("这是一个测试插件,goal是oseye");
}
}这个goal默认的是绑定validate阶段,但这个不能自动在validate阶段执行这个goal,必须配置:
<build>
<plugins>
<plugin>
<groupId>net.oseye</groupId>
<artifactId>MvnPluginDemo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<executions>
<execution>
<goals>
<goal>oseye</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>这是执行
mvn compile
首先是执行compile之前的phase,其中就有validate,因为配置中没有绑定phase,所以就默认validate。当执行到validate时就执行这个goal。但如果配置了
<build>
<plugins>
<plugin>
<groupId>net.oseye</groupId>
<artifactId>MvnPluginDemo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<executions>
<execution>
<phase>compile</phase>
<goals>
<goal>oseye</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>那么就是把这个goal绑定了compile阶段。
- 参数
插件可以接受从配置文件注入的数据,这里还是使用标注,格式是:@parameter expression="${aSystemProperty}" default-value="${anExpression}"插件代码
package net.oseye; import org.apache.maven.plugin.AbstractMojo;
import org.apache.maven.plugin.MojoExecutionException;
/**
* @goal oseye
* @phase validate
*/
public class MyMojo extends AbstractMojo{
/**
* @parameter expression=”${oseye.words}” default-value=”goodBye to you!”
*/
private String words;
public void execute()throws MojoExecutionException
{
getLog().info("这是一个测试插件,goal是oseye"+words);
}
}配置
<build>
<plugins>
<plugin>
<groupId>net.oseye</groupId>
<artifactId>MvnPluginDemo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<executions>
<execution>
<phase>compile</phase>
<goals>
<goal>oseye</goal>
</goals>
<configuration>
<words>goodbye everyone</words>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>输出
[INFO] 这是一个测试插件,goal是oseyegoodbye everyone
插件只有能够配置传参才具有生产意义。
自己动手编写Maven的插件的更多相关文章
- 自己动手编写一个VS插件(五)
作者:朱金灿 来源:http://blog.csdn.net/clever101 继续编写VisualStudio插件.这次我编写的插件叫DevAssist(意思是开发助手).在看了前面的文章之后你知 ...
- 自己动手编写一个VS插件(七)
作者:朱金灿 来源:http://blog.csdn.net/clever101 继续开发VS插件.今天在添加ATL控件时出现一个"未能返回新代码元素"的错误,如下图: 解决办法是 ...
- 自己动手编写一个Mybatis插件:Mybatis脱敏插件
1. 前言 在日常开发中,身份证号.手机号.卡号.客户号等个人信息都需要进行数据脱敏.否则容易造成个人隐私泄露,客户资料泄露,给不法分子可乘之机.但是数据脱敏不是把敏感信息隐藏起来,而是看起来像真的一 ...
- 自己动手编写一个VS插件(八)
作者:朱金灿 来源:http://blog.csdn.net/clever101 利用业余时间继续开发一个VS插件.我要开发的插件是一个代码库插件,主要是用于积累我平时要使用的代码.在之前我已经实现了 ...
- 自己动手编写一个VS插件(六)
作者:朱金灿 来源:http://blog.csdn.net/clever101 在上篇中我们已经实现了创建和显示一个工具栏出来,它的效果图是这样的: 现在我们实现一些简单功能,具体就是单击按钮弹出一 ...
- 自己动手编写vue插件
一.为什么要自己动手写插件呢,原因有二: 其一:是因为最近产品了提了一个在web端接收,消息通知的需求,产品要求在若干个页面内如果有消息,就要弹出消息弹窗展示给用户,略加思索之后,第一反应就是写个消息 ...
- 动手编写插件-javascript分页插件
原来公司用的报表分页插件是C#编写的服务器插件,需要前后台交互,而且不支持ajax. 经过一段时间折腾,我编写了一个轻便的jquery分页插件,支持ajax.下面是插件代码 /* 插件名称:报表分页 ...
- IDEA集成有道翻译插件/maven帮助插件/mybatis插件
(一)IDEA集成有道翻译插件:https://www.cnblogs.com/a8457013/p/7814335.html 插件下载地址:http://plugins.jetbrains.com/ ...
- OWIN系列之自己动手编写中间件
一.前言 1.基于OWIN的项目摆脱System.Web束缚脱颖而出,轻量级+跨平台,使得ASP.NET应用程序只需依赖这个抽象接口,不用关心所运行的Web服务器. 2.OWIN.dll介绍 使用反编 ...
随机推荐
- Windows 7 下 PHP 开发环境搭建(手动)
Windows 7 下 PHP 开发环境搭建 1.说明 做开发的都知道一句话,就是“站在巨人的肩膀上”.确实现在打开浏览器随便一搜很多一键安装PHP环境的软件,比如wamp.xampp.AppServ ...
- easelJS - Cache_vday
easelJS - Cache_vday $(function() { init(); }); // Cache_vday var canvas; var stage; var container; ...
- 如何使用Ninja快速编译LLVM和Clang
在使用Make工具编译LLVM是非常耗时的.往往需要三四个小时.但是使用goolge开源的ninja编译LLVM只需要10到20分钟. 本文以llvm3.3为例,演示在linux上编译和安装过程. 第 ...
- ZeroMQ 的模式
在需要并行化处理数据的时候,采用消息队列通讯的方式来协作,比采用共享状态的方式要好的多.Erlang ,Go 都使用这一手段来让并行任务之间协同工作. 最近读完了 ZeroMQ 的 Guide.写的很 ...
- 递归编译的Makefile的实现
最近写了一个递归Makefile,目的是既可以实现子模块的单独编译,也可以不做任何修改就和整个程序的整体进行无缝衔接的编译.具体的思路是借助第三方文件,将子模块编译好的.o文件的路径自动写到confi ...
- 3D游戏开发之在UE4中创建非玩家角色(NPC)
接着上节我们继续学习,现在我们来创建一些NPC(non-playable characters,非玩家角色).在这个游戏中,当我们靠近NPC时,它们会做出相应的反应. 一 创建C++类 1) 在UE编 ...
- 如何在Crystal框架项目中内置启动MetaQ服务?
当Crystal框架项目中需要使用消息机制,而项目规模不大.性能要求不高时,可内置启动MetaQ服务器. 分步指南 项目引入crystal-extend-metaq模块,如下: <depende ...
- Hadoop权威指南: 专有数据类型
Writable 和 WritableComparable接口 Writable接口 ** Writable接口的主要目的是,当数据在网络上传输或从硬盘读写时,提供数据的序列化和反序列化机智 ** * ...
- [css]《css揭秘》学习(二)-多重边框
一.box-shadow属性 box-shadow除了生成投影,还可以用来生成边框:它接受第4个值作为扩张半径,0的x轴偏移+0的y轴偏移+0的模糊值+0的扩张半径,得到的显示效果和边框是一样的:但是 ...
- 基于机器学习的web异常检测
基于机器学习的web异常检测 Web防火墙是信息安全的第一道防线.随着网络技术的快速更新,新的黑客技术也层出不穷,为传统规则防火墙带来了挑战.传统web入侵检测技术通过维护规则集对入侵访问进行拦截.一 ...