1. 程式人生 > >intelliJ 打包jar的多種方式

intelliJ 打包jar的多種方式

implement order all manifest body res 1-1 gin mave

這裏總結出用IntelliJ IDEA打包jar包的多種方式,以後的項目打包Jar包可以參考如下形式:

  1. 用IDEA自帶的打包形式
  2. 用Maven插件maven-shade-plugin打包
  3. 用Maven插件maven-assembly-plugin打包

用IDEA自帶的打包方式:

打開IDEA的file -> Project Structure,進入項目配置頁面。如下圖:

點擊Artifacts,進入Artifacts配置頁面,點擊 + ,選擇如下圖的選項。

進入Create JAR from Modules頁面,按照如下圖配置。

  1. 第一步選擇Main函數執行的類。
  2. 第二步選擇如圖的選項,目的是對第三方Jar包打包時做額外的配置,如果不做額外的配置可不選這個選項(但不保證打包成功)
  3. 第三步需要在src/main目錄下,新建一個resources目錄,將MANIFEST.MF文件保存在這裏面,因為如果用默認缺省值的話,在IDEA12版本下會有bug。

點擊OK之後,出現如下圖界面,右鍵點擊<output root>,點擊Create Directory,創建一個libs,將所有的第三方JAR放進libs目錄下。

技術分享

成功之後,如下圖所示:

技術分享

放入之後,點擊我們要打成的jar的名字,這裏面是kafka-cps.jar,選擇classpath進行配置。

編輯的結果如下:

技術分享

這裏將所有的jar都寫在libs/裏面。點擊OK,回到配置頁面。
同時還註意在配置頁面,勾選build on make
技術分享

最後點擊配置頁面的OK,完成配置。回到IDEA,點擊Build->Build Artifacts,選擇build

技術分享

就會生成我們需要的jar包。其位置在項目目錄的out目錄下/out/artifacts/kafka_cps_jar
下面放一個正確配置的清單文件內容

技術分享

用maven-shade-plugin打包

上面的打包過程實在是過於的繁瑣,而且也沒有利用到maven管理項目的特色。為此,我們這裏利用maven中的maven-shade-plugin

插件。在pom.xml中,我們加入如下的信息來加入插件。

<plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-shade-plugin</artifactId>
                <version>1.4</version>
                <configuration>
                    <createDependencyReducedPom>true</createDependencyReducedPom>
                </configuration>
                <executions>
                    <execution>
                        <phase>package</phase>
                        <goals>
                            <goal>shade</goal>
                        </goals>
                        <configuration>
                            <transformers>
                                <transformer
                                        implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                                    <mainClass>Main.Main</mainClass>
                                </transformer>
                            </transformers>
                        </configuration>
                    </execution>
                </executions>
            </plugin>

這裏面配置了一個`configuration`標簽內容,在此標簽下面 有一個transformer標簽,用來配置Main函數的入口( <mainClass>Main.Main</mainClass>),當然此標簽內容很復雜,不是上面寫的那麽簡單,上面之所以如此簡單,是因為在所有類中(包括第三方Jar)只有一個Main方法。如果第三方jar中有Main方法,就要進行額外的配置,上面這麽配置,不一定能執行成功。

具體可以參見maven插件。

在加入這段代碼到pom.xml之後,我們就可以用maven的命令去打包了。其指令如下:

mvn clean compile //清除之前target編譯文件並重新編譯
mvn clean package //對項目進行打包(因為配置過插件,所以jar包是可執行的)
mvn clean install //安裝項目,然後就可以使用了

然後通過java -jar cps-1.0-SNAPSHOT.jar運行。

如果使用IDEA的話,可以通過自帶的maven管理工具代替執行上面的命令。如下圖所示,依次點擊藍色的部分。

技術分享

用maven-assembly-plugin打包

上面的方法,我們還需要點擊很多命令去打包。這次利用一個新的插件,可以打包更簡單。同樣,在pom.xml中加入如下代碼。上文的maven-shade-plugin插件代碼可以刪除。最好不要寫2個插件代碼。

 <plugin>
                <artifactId>maven-assembly-plugin</artifactId>
                <version>2.4</version>
                <configuration>
                    <descriptorRefs>
                        <descriptorRef>jar-with-dependencies</descriptorRef>
                    </descriptorRefs>
                    <archive>
                        <manifest>
                            <mainClass>Main.Main</mainClass>
                        </manifest>
                    </archive>
                </configuration>
                <executions>
                    <execution>
                        <id>make-assembly</id>
                        <phase>package</phase>
                        <goals>
                            <goal>single</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>

這裏同樣配置了一個manifest標簽來配置Main函數的入口。然後通過如下指令來實現打包。

mvn assembly:assembly

如果使用IDEA的話,可以通過自帶的maven管理工具代替執行上面的命令。如下圖所示,點擊藍色的部分。

技術分享

然後通過執行java -jar cps-1.0-SNAPSHOT-jar-with-dependencies.jar運行。

intelliJ 打包jar的多種方式