自己动手编写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介绍 使用反编 ...
随机推荐
- 2.4. 属性(Core Data 应用程序实践指南)
属性的名称必须以小写字母开头. 添加 name 和 quantity 属性.
- ASP.NET MVC TempData使用心得
说明: 在ASP.NET MVC中資料傳遞主要有ViewData與TempData ViewData主要是Controller傳遞Data給View,存留期只有一個Action,要跨Action要使用 ...
- Angular - - filter 过滤器
Filter Ng里的过滤器. currency:把一个数字格式化成货币模式(如$1,234.56).当没有提供任何货币符号时,默认使用当前区域的符号. 使用: HTML:{{ currency_ex ...
- Angular - - ngRoute Angular自带的路由
ngRoute $routeProvider 配置路由的时候使用. 方法: when(path,route); 在$route服务里添加一个新的路由. path:该路由的路径. route:路由映射信 ...
- --@angularJS--简单的带嵌套的指令demo
<!DOCTYPE HTML><html ng-app="app"><head> <title>custom-directiv ...
- Unity3D中切换场景可能导致材质变暗的问题
Unity版本:5.1.1f1 做公司项目的时候,无意间发现了一个很奇葩的现象:场景A(纯UI,故没有光源)转场到场景B的时候,B中原有的光源似乎失效了,但在Hierarchy窗口中能够看到光源存在, ...
- overflow:hidden 你所不知道的事
overflow:hidden 你所不知道的事 overflow:hidden这个CSS样式是大家常用到的CSS样式,但是大多数人对这个样式的理解仅仅局限于隐藏溢出,而对于清除浮动这个含义不是很了解. ...
- Postman编程
Postman常用Api Postman像jmeter一样提供前置处理脚本和后置处理脚本.脚本主要使用JavaScript语法,并内置提供了一些js代码库,提供了一些内置对象和方法. 参考:https ...
- 关于MVC结构
简单的记录,只是想记录一下现在对MVC的理解. MVC,即模型(MODEL),视图(VIEW),控制器(CONTROLLER) 模型是数据模型 视图是图形界面 控制器是在两个之间的控制部分,用来将数据 ...
- ADXL345经验总结,采用SPI和I2C总线操作
一. ADXL345简介 ADXL345是ADI公司推出的三轴(x,y,z)iMEMS数字加速度计(digital accelerometer),具有在16G下高分辨率(13Bit)测量能 ...