- 浏览: 1088129 次
- 性别:
- 来自: 杭州
-
文章分类
- 全部博客 (399)
- C++ (39)
- Java (74)
- Java界面开发学习笔记 (4)
- Java用户的c++之旅 (0)
- 自言自语 (12)
- DSP (1)
- MCU (0)
- CG (0)
- Jabber (0)
- Gloox (0)
- Linux (11)
- Windows (19)
- Networks (4)
- Jobs (0)
- PHP (1)
- JSP (2)
- 生活 (35)
- C (2)
- Qt4 (2)
- C# (50)
- WPF (5)
- ASP (2)
- FLEX (47)
- SQL (20)
- JavaScript (12)
- SharePoint (6)
- GWT (1)
- Dojo (9)
- HTML (11)
- Others (7)
- 如何安装配置系列 (7)
- UML (2)
- Android (3)
- alibaba (1)
最新评论
-
zxjlwt:
学习了http://surenpi.com
Firefox插件开发: Hello World! -
ylldzz:
楼主知道MVEL怎么调试么
MVEL简介及快速使用 -
blueman2012:
您好,可否提供源码下载,我把您的代码贴过来后,好多报错的,谢谢 ...
Log4J日志解析 -
svygh123:
你的游标都没有关闭呢!
MYSQL游标嵌套循环示例 -
dizh:
写的很好啊
MVEL简介及快速使用
Maven 插件开发—-让maven使用更加灵活 对于习惯于使用maven构建、管理项目的人来说,maven就是项目开发、测试、部署的一把利器:对类库的集中管理;依赖传递、继承、重用性高;对整个项目开发生命周期的完整支持,从头到尾只需要几个简单的命令就可以快速地遍历整个开发周期,减轻了配置管理的工作量。这些优秀的功能都是通过maven插件库里提供的丰富插件来完成的。因此,掌握maven插件开发、在实际工作中根据自己的需要开发适合自己需求maven插件,是很有必要的。 这篇文章先从动手实践开始,迅速开发出自己的一个maven插件,然后根据主要构建过程和配置予以简单说明。 1,创建一个maven-plugin目录,并通过CMD程序从后台进入此目录。 2,运行命令: mvn archetype:create -DgroupId=com.taobao.maven -DartifactId=maven-hello-plugin -DarchetypeArtifactId=maven-archetype-mojo 3,进入maven-hello-plugin目录,运行命令:mvn eclipse:eclipse构建eclipse工程。 4,通过eclipse import工程,删除包下面自动生成的java文件,新建GreetingMojo.java和GoodByeMojo.java,分别对应打招呼、再见两个动作。 GreetingMojo.java的内容如下: package com.taobao.maven; import org.apache.maven.plugin.AbstractMojo; import org.apache.maven.plugin.MojoExecutionException; /** * @goal greeting */ public class GreetingMojo extends AbstractMojo { /** * @parameter expression=”${greeting.words}” default-value=”Hello to you!” */ private String words ; public void execute() throws MojoExecutionException { getLog().info(words); } } GoodByeMojo.java的内容如下: package com.taobao.maven; import org.apache.maven.plugin.AbstractMojo; import org.apache.maven.plugin.MojoExecutionException; import org.apache.maven.plugin.MojoFailureException; /** * @goal goodBye */ public class GoodByeMojo extends AbstractMojo { /** * @parameter expression=”${goodBye.words}” default-value=”goodBye to you!” */ private String words; public void execute() throws MojoExecutionException, MojoFailureException { getLog().info(words); } } 5, 文件编写完成后回到cmd命令行,在项目的pom文件目录处运行install命令将插件安装到本地repository:mvn clean install 6, 安装成功后继续运行如下命令查看插件的运行情况: 运行: mvn com.taobao.maven:maven-hello-plugin:1.0-SNAPSHOT:greeting ,可以看到控制台看到输出:“Hello to you!”;这个输出是插件的默认参数: default-value=”Hello to you!” 运行 mvn com.taobao.maven:maven-hello-plugin:1.0-SNAPSHOT:goodBye ,可以在控制台看到输出:“goodBye to you!”;这个输出是插件的默认参数: default-value=”goodBye to you!” 运行: mvn com.taobao.maven:maven-hello-plugin:1.0-SNAPSHOT:greeting -Dgreeting.words=”welcome!” 可以在控制台看到输出:“welcome!”;这个在命令中明确指定插件的参数,因此输出的是指定的参数“welcome!”。 运行 mvn com.taobao.maven:maven-hello-plugin:1.0-SNAPSHOT:goodBye -DgoodBye.words=”see you!” 可以在控制台看到输出:“see you!”;这个在命令中明确指定插件的参数,因此输出的是指定的参数“see you!”。 7,至此,一个“见面寒暄”的简单maven插件基本完成。 1,MOJO Maven 通过插件动作完成大多数构建任务。可以把 Maven 引擎认为是插件动作的协调器。插件中的每个任务goal称作一个 Mojo(Maven plain Old Java Object)。项目中每一个Mojo都要实现org.apache.maven.plugin.Mojo接口,上面的插件示例的Mojo通过扩展org.apache.maven.plugin.AbstractMojo类实现了该接口。Mojo提供过了如下的方法: void setLog( org.apache.maven.monitor.logging.Log log ) 每一个Mojo实现都必须提供一种方法让插件能够和某个特定目标的过程相交流。该目标成功了么?或者,是否在运行目标的时候遇到了问题?当Maven加载并运行Mojo的时候,它会调用setLog()方法,为Mojo实例提供正确的日志目标,以让你在自定义插件中使用。 protected Log getLog() Maven会在Mojo运行之前调用setLog()方法,然后你的Mojo就可以通过调用getLog()获得日志对象。Mojo应该去调用这个Log对象的方法,而不是直接将输出打印到标准输出或者控制台。 void execute() throws org.apache.maven.plugin.MojoExecutionException 轮到运行目标的时候,Maven就会调用该方法。 Mojo接口只关心两件事情:目标运行结果的日志记录,以及运行一个目标。当编写自定义插件的时候,需要扩展AbstractMojo。AbstractMojo处理setLog()和getLog()的实现,并包含一个抽象的execute()方法。在扩展AbstractMojo的时候,你所需要做的只是实现execute()方法。 2,Phase Maven 对构建生命周期的固定理解包含了许多不同的阶段,如下表: 3,插件组成 每一个mojo都由一些注解annotation来描述,这些注解是在java类的上面标注。常用的几个注解如下: execute:注解形式: a), @execute phase=”<phaseName>” lifecycle=”<lifecycleId>”; b), @execute phase=”<phaseName>” c), @execute goal=”<goalName>” 当这个目标goal被调用时,它会先调用一个平行的生命周期,在制定的阶段结束。如果插件没有被指定阶段,这一目标将会单独执行。 goal:注解形式:@goal <goalName> 用户在命令行下直接调用插件的目标goal,或者在项目的pom文件中通过配置调用这个goal。 phase:注解形式:@phase <phaseName> 绑定这个mojo到标准构建生命周期里对应的阶段。 对于一个mojo里的变量参数,也有一些常用的注解: configuration:注解形式: @parameter expression=”${aSystemProperty}” default-value=”${anExpression}” 对参数指定一个计算表达式、在mojo构建时将计算结果注入到此变量中,同时也可以给定一个默认值。这个参数值也可以在pom文件中予以配置。 伴随插件开发完成,在被其他项目使用时有比较多的、灵活的配置,接下来也通过一个示例来使用这个插件。 1,回到maven-plugin目录,创建插件测试工程: mvn archetype:create -DgroupId=com.taobao.maven -DartifactId=plugin-test -Dpackaging=jar 2,在测试工程的pom文件中加入插件依赖: <build> <plugins> <plugin> <groupId>com.taobao.maven</groupId> <artifactId>maven-hello-plugin</artifactId> <version>1.0-SNAPSHOT</version> </plugin> </plugins> </build> 3,在上述配置后可以使用这个插件了,但是这个插件在开发的时候并没有定义插件运行的生命周期,而且,在使用时也希望得到更加灵活的参数配置,因此在使用时大多采用如下的配置: <plugin> <groupId>com.taobao.maven</groupId> <artifactId>maven-hello-plugin</artifactId> <version>1.0-SNAPSHOT</version> <executions> <execution> <id>compile phase</id> <phase>compile</phase> <goals> <goal>greeting</goal> </goals> <configuration> <words>hello everyone</words> </configuration> </execution> <execution> <id>test phase</id> <phase>test</phase> <goals> <goal>goodBye</goal> </goals> <configuration> <words>goodbye everyone</words> </configuration> </execution> </executions> </plugin> 这个配置对这个插件定义了运行时的生命周期,在编译compile阶段运行插件的greeting 目标,输出greeting.words是“hello everyone”;在测试test阶段运行插件的goodBye 目标,输出goodBye.words是“goodbye everyone”。配置完成后,回到命令行的plugin-test工程目录下运行:mvn clean package,即可看到对应阶段的输出信息。 Maven–工作因你而简单! 转自:http://qa.taobao.com/?p=4964(淘宝QA)一,快速开发你的第一个插件
二,插件开发过程的相关说明
validate
验证
确保当前配置和POM的内容是有效的。这包含对pom文件树的验证。
initialize
初始化
在执行构建生命周期的主任务之前可以进行初始化。
generate-sources
生成源码
代码生成器可以开始生成在以后阶段中处理或编译的源代码。
process-sources
处理源码
提供解析、修改和转换源码。常规源码和生成的源码都可以在这里处理。
generate-resources
生成资源
可以生成非源码资源。通常包括元数据文件和配置文件。
process-resources
处理资源
处理非源码资源。修改、转换和重定位资源都能在这阶段发生。
compile
编译
编译源码。编译过的类被放到目标目录树中。
process-classes
处理类
处理类文件转换和增强步骤。字节码交织器和常用工具常在这一阶段操作。
generate-test-sources
生成测试源码
mojo可以生成要操作的单元测试代码。
process-test-sources
处理测试源码
在编译前对测试源码执行任何必要的处理。在这一阶段,可以修改、转换或复制源代码。
generate-test-resources生成测试资源
允许生成与测试相关的(非源码)资源。
process-test-resources处理测试资源
可以处理、转换和重新定位与测试相关的资源。
test-compile
测试编译
编译单元测试的源码。
test
测试
运行编译过的单元测试并累计结果。
package
打包
将可执行的二进制文件打包到一个分布式归档文件中,如
pre-integration-test
前集成测试、准备集成测试。这种情况下的集成测试是指在一个受到一定控制的模拟的真实部署环境中测试代码。这一步能将归档文件部署到一个服务器上执行。
integration-test
集成测试
执行真正的集成测试。
post-integration-test
后集成测试、解除集成测试准备。这一步涉及测试环境重置或重新初始化。
verify
检验
检验可部署归档的有效性和完整性。过了这个阶段,将安装该归档。
install
安装
将该归档添加到本地Maven目录。这一步让其他可能依赖该归档的模块可以使用它。
deploy
部署
将该归档添加到远程Maven目录。这一步让这个工件能为更多的人所用。
三,在其他工程中使用此插件
发表评论
-
Interesting interview question…
2011-06-23 19:10 1498Today I was asked this questi ... -
简单易用的Web框架:SummerCool介绍
2011-05-10 19:01 4775SummerCool是国内某大型电子商务平台的架构师自 ... -
[转]Eclipse插件:Java AST View
2011-05-06 16:03 4643转载:http://www.blogjava.net/life ... -
Eclipse之Debug技巧
2011-05-02 15:30 1590你认为你的eclipse debug技能都学会了吗?能够熟 ... -
AccessController.doPrivileged 小记
2011-04-29 20:29 2115原文:http://blog.csdn.net/tea ... -
推荐一个下载源码的网站
2011-04-29 20:26 1284http://olex.openlogic.com/ 这个网 ... -
Java解析xml禁止校验dtd
2011-04-27 21:34 8449今天在做log4j.xml解析的时候,指定了如下的dtd声明: ... -
区分getName、getCanonicalName与getSimpleName
2011-04-27 18:34 5786举例,现有一个类如下: package com.sha ... -
Log4J日志解析
2011-04-25 16:12 7105在有些场景下,需要解析Log4J的日志,以为己用。比如,根据 ... -
分享个不错的网站:看JSON字符串的利器
2011-04-20 20:09 1346分享个不错的网站:看JSON字符串的利器or胸器 http: ... -
Regex:密码验证
2011-04-13 18:45 20474.当且仅当含数字和字母的密码验证 如果密码当且仅当 ... -
JDBC操作数据库时切记关闭资源
2011-04-08 18:14 1921Error: No ManagedConnectio ... -
JDBC:如何将resultset的信息自动封装到pojo里面
2011-04-08 10:32 4340不多说了 直接上代码 Java代码 p ... -
Maven自动升级版本号并打包上传的脚本
2011-04-02 09:52 7573同事写的自动升级版本并打包上传的脚本: echo of ... -
在ibatis中使用$value$引入变量会引入SQLInjection漏洞
2011-04-01 16:26 2336(1)sql语法中的_关键字_.如果sql语句中出现存在用户输 ... -
EqualsBuilder和HashCodeBuilder
2011-03-31 19:30 2249自动化hashCode()和equals() 问题产生:当需 ... -
Eclipse中的Stack Trace Console的使用
2011-03-15 14:47 3058很多的Java程序员(特别是开发Web程序的时候),通常在 ... -
System.out.format的使用
2011-01-21 12:34 4821JDK5.0允许象C语言那样直接用printf()方法来格式化 ... -
jhat的简单使用
2011-01-18 19:41 2917leak一般会发生在容器类保存对象引用而不删除的时候,替代方法 ... -
关于变更eclipse中maven插件的repository路径
2011-01-10 10:02 17301.打开eclipse 2.window-->ref ...
相关推荐
Maven包冲突是Java开发中常见的问题,理解其原理和解决方法对于优化项目构建和提高代码质量至关重要。通过合理地配置POM文件,使用Maven的特性以及辅助工具,可以有效地管理项目依赖,避免和解决包冲突,确保项目的...
浅谈IDEA中Maven配置问题全解决 IDEA 作为一款功能强大的集成开发环境(Integrated Development Environment),广泛应用于 Java 项目开发中。Maven则是 Java 项目管理和构建工具,用于管理项目依赖关系和编译、...
manager-gui角色允许用户通过HTML界面进行热部署操作,而manager-script角色则允许通过脚本或maven插件进行自动部署。 在使用maven进行热部署时,需要在项目的pom.xml文件中增加tomcat7-maven-plugin插件配置。这个...
在脚本解读部分,我们看到了maven插件的应用,以及如何定义生成Javadoc和Sources Jar的任务。这些任务将帮助我们自动生成文档和源代码包,它们是Java开发中非常重要的资料。 最后,我们要注意,由于OCR扫描可能导致...
最新版本的 Android Gradle 插件包括许多更新,包括构建速度的优化,对 Maven 发布插件的支持以及对视图绑定(View Binding)的支持。 View Binding View binding 可以在代码中引用视图时提供编译时安全性。现在,...
例如,Maven的`maven-jar-plugin`插件允许你自定义`MANIFEST.MF`文件,指定多个`main-class`,或者创建一个包含所有依赖的"fat" JAR(又称为uber或one-jar)。 总结一下,Java执行JAR包中的`main`方法有两种主要...