溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用maven自定義插件開發(fā)

發(fā)布時間:2022-06-15 11:47:53 來源:億速云 閱讀:172 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹了如何使用maven自定義插件開發(fā)的相關知識,內(nèi)容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇如何使用maven自定義插件開發(fā)文章都會有所收獲,下面我們一起來看看吧。

Maven 插件的命名規(guī)范

一般來說,我們會將自己的插件命名為 -maven-plugin,而不推薦使用 maven--plugin,因為后者是 Maven 團隊維護官方插件的保留命名方式,使用這個命名方式會侵犯 Apache Maven 商標。

什么是 Mojo?

Mojo 就是 Maven plain Old Java Object。每一個 Mojo 就是 Maven 中的一個執(zhí)行目標(executable goal),而插件則是對單個或多個相關的 Mojo 做統(tǒng)一分發(fā)。一個 Mojo 包含一個簡單的 Java 類。插件中多個類似 Mojo 的通用之處可以使用抽象父類來封裝。

創(chuàng)建 Mojo 工程

這里,我們使用 Idea 作為開發(fā)工具進行講解,創(chuàng)建工程選擇 Maven,然后在模板中找到 maven-archetype-mojo,點擊下一步,輸入對應的參數(shù),如:com.qchery/ekjar-maven-plugin/1.0-SNAPSHOT,最后點擊完成即可創(chuàng)建一個簡單的 Mojo 工程。

Maven 插件的命名規(guī)范

一般來說,我們會將自己的插件命名為 -maven-plugin,而不推薦使用 maven--plugin,因為后者是 Maven 團隊維護官方插件的保留命名方式,使用這個命名方式會侵犯 Apache Maven 商標。

什么是 Mojo?

Mojo 就是 Maven plain Old Java Object。每一個 Mojo 就是 Maven 中的一個執(zhí)行目標(executable goal),而插件則是對單個或多個相關的 Mojo 做統(tǒng)一分發(fā)。一個 Mojo 包含一個簡單的 Java 類。插件中多個類似 Mojo 的通用之處可以使用抽象父類來封裝。

創(chuàng)建 Mojo 工程

這里,我們使用 Idea 作為開發(fā)工具進行講解,創(chuàng)建工程選擇 Maven,然后在模板中找到 maven-archetype-mojo,點擊下一步,輸入對應的參數(shù),如:com.qchery/ekjar-maven-plugin/1.0-SNAPSHOT,最后點擊完成即可創(chuàng)建一個簡單的 Mojo 工程。

如何使用maven自定義插件開發(fā)

創(chuàng)建完成后,工程內(nèi)會生成對應的 pom.xml 文件。其內(nèi)容比較簡單,與普通 Maven 工程的 pom.xml 基本一致,只是自動添加了對 maven-plugin-api 的依賴,這個依賴里面會包含一些 Mojo 的接口與抽象類,在后續(xù)編寫具體的 Mojo 時再進行詳細講解。

<dependency>
  <groupId>org.apache.maven</groupId>
  <artifactId>maven-plugin-api</artifactId>
  <version>2.0</version>
</dependency>

與普通 pom.xml 文件一個重要的不同之處是它的打包方式:

<packaging>maven-plugin</packaging>

簡單 Mojo 的創(chuàng)建

工程創(chuàng)建完畢后,我們開始 Mojo 創(chuàng)建之旅,上面提到過 Mojo 是一個簡單的 Java 類,那我們創(chuàng)建第一個 Mojo 類用于打印一行輸出。

import org.apache.maven.plugin.AbstractMojo;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugin.MojoFailureException;
/**
 * @goal hello
 */
public class HelloMojo extends AbstractMojo {
    public void execute() throws MojoExecutionException, MojoFailureException {
        System.out.println("hello world");
    }
}

觀察一下這個類,我們發(fā)現(xiàn)它繼承了 AbstractMojo 這個抽象類,并實現(xiàn)了 execute() 方法,該方法就是用來定義這個 Mojo 具體操作內(nèi)容,我們只需要根據(jù)自己的需要來編寫自己的實現(xiàn)即可。

Mojo 操作的實現(xiàn)我們了解了,那怎么讓 Maven 知道這是一個 Mojo 而不是一個普通的 Java 類呢?這里,就需要說一下 Mojo 的查找機制了,在處理源碼的時候,plugin-tools 會把使用了 @Mojo 注解或 Javadoc 里包含 @goal 注釋的類來當作一個 Mojo 類。在上面的例子中,我們使用了 Javadoc 的方法來聲明一個 Mojo。同樣我們也可以使用 @Mojo 注解來進行聲明:

@Mojo(name = "hello")
public class HelloMojo extends AbstractMojo {
    public void execute() throws MojoExecutionException, MojoFailureException {
        System.out.println("hello world");
    }
}

使用 @Mojo 注解,我們需要引入一個新包:

<dependency>
  <groupId>org.apache.maven.plugin-tools</groupId>
  <artifactId>maven-plugin-annotations</artifactId>
  <version>3.1</version>
</dependency>

運行自定義 Plugin

與使用其它插件類似,我們需要在 pom.xml 文件中引入插件:

<build>
    <plugins>
        <plugin>
            <groupId>com.qchery</groupId>
            <artifactId>ekjar-maven-plugin</artifactId>
            <version>1.0-SNAPSHOT</version>
        </plugin>
    </plugins>
</build>

先執(zhí)行命令:

mvn install

然后執(zhí)行:

mvn com.qchery:ekjar-maven-plugin:1.0-SNAPSHOT:hello

即可看到輸出:

[INFO] Scanning for projects...
[INFO]                                                                         
[INFO] ------------------------------------------------------------------------
[INFO] Building ekjar-maven-plugin Maven Mojo 1.0-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO] 
[INFO] --- ekjar-maven-plugin:1.0-SNAPSHOT:hello (default-cli) @ ekjar-maven-plugin ---
hello world
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 0.249 s
[INFO] Finished at: 2017-03-26T12:59:47+08:00
[INFO] Final Memory: 6M/123M
[INFO] ------------------------------------------------------------------------

縮短執(zhí)行命令

在剛才運行插件的時候,我們使用全量的插件指引,但這個實在是太長太繁瑣了,那我們是否可以縮短我們的執(zhí)行命令呢?

答案肯定是可以的,如果你想要執(zhí)行的是你本地庫中最新版本的插件,那么你可以刪除掉版本號;如果你的命名滿足前面提及的兩種命令方式,你可以直接使用插件名及 goal 名來運行對應的插件,如:

mvn ekjar:hello

你會得到與之前完全一樣的結(jié)果。

綁定 Maven 執(zhí)行周期

你還可以將插件配置為將特定目標,從而附加到構(gòu)建生命周期中的某個特定階段。如:

<build>
    <plugins>
        <plugin>
            <groupId>com.qchery</groupId>
            <artifactId>ekjar-maven-plugin</artifactId>
            <version>1.0-SNAPSHOT</version>
            <executions>
                <execution>
                    <goals>
                        <goal>hello</goal>
                    </goals>
                    <phase>package</phase>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

繼承AbstractMojo 的類中,參數(shù)可以通過命令賦值,例如:

/**
 *
 * @goal echo
 * @phase process-sources
 */
public class MyMojo extends AbstractMojo {
    /**
     * @parameter expression="${echo.message}" default-value="Hello World..."
     */
    private String message;
    public void execute() throws MojoExecutionException, MojoFailureException {
        System.out.println("hello world");
        getLog().info("hello mymojo : "+message);
    }
}

其中注釋就是maven插件很重要的元數(shù)據(jù)

/**
 * @goal CustomMavenMojo:表示該插件的服務目標
 * @phase compile:表示該插件的生效周期階段
 * @requiresProject false:表示是否依托于一個項目才能運行該插件
 * @parameter expression="${name}":表示插件參數(shù),使用插件的時候會用得到
 * @required:代表該參數(shù)不能省略
 */

執(zhí)行:

mvn com.handarui.yanquan:yanquan:1.0-SNAPSHOT:echo -Decho.message="The Eagle has Landed"

(MyMojo類中的message 參數(shù)的javadoc注釋是 echo.message, 通過命令賦值時,需要傳入-Decho.message=XXX 這種形式 )

關于“如何使用maven自定義插件開發(fā)”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“如何使用maven自定義插件開發(fā)”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI