欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Maven將代碼及依賴打成一個(gè)Jar包的方式詳解(最新推薦)

 更新時(shí)間:2023年05月27日 09:17:48   作者:章三豐  
這篇文章主要介紹了Maven將代碼及依賴打成一個(gè)Jar包的方式,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

Maven可以使用mvn package指令對(duì)項(xiàng)目進(jìn)行打包,如果使用java -jar xxx.jar執(zhí)行運(yùn)行jar文件,會(huì)出現(xiàn)"no main manifest attribute, in xxx.jar"(沒(méi)有設(shè)置Main-Class)、ClassNotFoundException(找不到依賴包)等錯(cuò)誤。

要想jar包能直接通過(guò)java -jar xxx.jar運(yùn)行,需要滿足:

1、在jar包中的META-INF/MANIFEST.MF中指定Main-Class,這樣才能確定程序的入口在哪里;

2、要能加載到依賴包。

使用Maven有以下幾種方法可以生成能直接運(yùn)行的jar包并且是打成一個(gè)jar包,可以根據(jù)需要選擇一種合適的方法。

方法一:使用maven-assembly-plugin插件打包

在pom.xml中配置:

<build>
	<plugins>
		<plugin>
			<groupId>org.apache.maven.plugins</groupId>
			<artifactId>maven-assembly-plugin</artifactId>
			<version>2.5.5</version>
			<configuration>
				<archive>
					<manifest>
						<mainClass>com.xxg.Main</mainClass>
					</manifest>
				</archive>
				<descriptorRefs>
					<descriptorRef>jar-with-dependencies</descriptorRef>
				</descriptorRefs>
			</configuration>
		</plugin>
	</plugins>
</build>

打包方式: mvn package assembly:single(在eclipse中執(zhí)行maven build…… ,然后在Goals中輸入 assembly:single)

打包后會(huì)在target目錄下生成一個(gè)xxx-jar-with-dependencies.jar文件,這個(gè)文件不但包含了自己項(xiàng)目中的代碼和資源,還包含了所有依賴包的內(nèi)容。所以可以直接通過(guò)java -jar來(lái)運(yùn)行。

此外還可以直接通過(guò)mvn package來(lái)打包(在eclipse中直接執(zhí)行maven install),無(wú)需assembly:single,不過(guò)需要加上一些配置:

<build>
	<plugins>
		<plugin>
			<groupId>org.apache.maven.plugins</groupId>
			<artifactId>maven-assembly-plugin</artifactId>
			<version>2.5.5</version>
			<configuration>
				<archive>
					<manifest>
						<mainClass>com.xxg.Main</mainClass>
					</manifest>
				</archive>
				<descriptorRefs>
                                             <!-- 這個(gè)jar-with-dependencies是assembly預(yù)先寫好的一個(gè),組裝描述引用 -->
					<descriptorRef>jar-with-dependencies</descriptorRef>
				</descriptorRefs>
                                        <!--工程名-->                                        
                                        <finalName>${project.name}</finalName>
			</configuration>
			<executions>
				<execution>
					<id>make-assembly</id>
					<phase>package</phase>
					<goals>
						<goal>single</goal>
					</goals>
				</execution>
			</executions>
		</plugin>
	</plugins>
</build>

其中<phase>package</phase>、<goal>single</goal>即表示在執(zhí)行package打包時(shí),執(zhí)行assembly:single,所以可以直接使用mvn package打包。

不過(guò),如果項(xiàng)目中用到Spring Framework,用這種方式打出來(lái)的包運(yùn)行時(shí)會(huì)出錯(cuò),使用下面的方法二可以處理。

方法二:使用maven-shade-plugin插件打包

在pom.xml中配置:

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

配置完成后,執(zhí)行mvn package即可打包。在target目錄下會(huì)生成兩個(gè)jar包,注意不是original-xxx.jar文件,而是另外一個(gè)。和maven-assembly-plugin一樣,生成的jar文件包含了所有依賴,所以可以直接運(yùn)行。

如果項(xiàng)目中用到了Spring Framework,將依賴打到一個(gè)jar包中,運(yùn)行時(shí)會(huì)出現(xiàn)讀取XML schema文件出錯(cuò)。原因是Spring Framework的多個(gè)jar包中包含相同的文件spring.handlers和spring.schemas,如果生成一個(gè)jar包會(huì)互相覆蓋。為了避免互相影響,

可以使用AppendingTransformer來(lái)對(duì)文件內(nèi)容追加合并:

<build>
	<plugins>
		<plugin>
			<groupId>org.apache.maven.plugins</groupId>
			<artifactId>maven-shade-plugin</artifactId>
			<version>2.4.1</version>
			<executions>
				<execution>
					<phase>package</phase>
					<goals>
						<goal>shade</goal>
					</goals>
					<configuration>
						<transformers>
							<transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
								<mainClass>com.xxg.Main</mainClass>
							</transformer>
							<transformer implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
								<resource>META-INF/spring.handlers</resource>
							</transformer>
							<transformer implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
								<resource>META-INF/spring.schemas</resource>
							</transformer>
						</transformers>
					</configuration>
				</execution>
			</executions>
		</plugin>
	</plugins>
</build>

方法三:使用maven-jar-plugin和maven-dependency-plugin插件打包

原理是通過(guò)修改maven 打jar包的maven-jar-plugin插件的配置信息來(lái)生成我們需要的指定依賴的可執(zhí)行jar包。

在項(xiàng)目的pom.xml文件中修改默認(rèn)的jar插件

<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-jar-plugin</artifactId>
            <version>2.3.1</version>
            <configuration>
                <archive>
                    <manifest>
                        <!--運(yùn)行jar包時(shí)運(yùn)行的主類,要求類全名-->
                        <mainClass>com.hafiz.Runner</mainClass>
                        <!-- 是否指定項(xiàng)目classpath下的依賴 -->
                        <addClasspath>true</addClasspath>
                        <!-- 指定依賴的時(shí)候聲明前綴 -->
                        <classpathPrefix>./lib/</classpathPrefix>
                        <!--依賴是否使用帶有時(shí)間戳的唯一版本號(hào),如:xxx-1.3.0-20121225.012733.jar-->
                        <useUniqueVersions>false</useUniqueVersions>
                    </manifest>
                </archive>
            </configuration>
        </plugin>
    </plugins>
</build>
<!--接著我們還要配置maven的maven-dependency-plugin插件把當(dāng)前項(xiàng)目的所有依賴放到target目錄下的lib文件夾下-->
<plugin>
   <groupId>org.apache.maven.plugins</groupId>
   <artifactId>maven-dependency-plugin</artifactId>
   <executions>
      <execution>
        <id>copy</id>
        <phase>package</phase>
        <goals>
           <goal>copy-dependencies</goal>
        </goals>
        <configuration>
           <outputDirectory>${project.build.directory}/lib</outputDirectory>
        </configuration>
     </execution>
   </executions>
</plugin>

其中,${project.build.directory}表示默認(rèn)的target文件夾。

我們通過(guò)上文的修改便完成了適用maven生成指定依賴的可執(zhí)行jar包。

我們發(fā)現(xiàn)生成的manifest文件中已經(jīng)設(shè)置好了Main-Class以及Class-Path,如下:

如果<addClasspath>設(shè)置為false,則生成的manifest文件中不會(huì)聲明依賴(即不會(huì)有Class-Path聲明)

程序主類如下:

package com.hafiz;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
/**
 * Desc:主類
 * Created by hafiz.zhang on 2018/4/07.
 */
public class Runner {
    public static void main(String[] args) {
        ApplicationContext context 
        = new ClassPathXmlApplicationContext("classpath:applicationContext.xml");
        System.out.println("context:" + context.getClass());
        System.out.println("The Main Class Is Running....");
    }
}

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/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.hafiz</groupId>
    <artifactId>assembly-demo</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>jar</packaging>
    <name>assembly-demo</name>
    <url>http://maven.apache.org</url>
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <spring.version>4.2.6.RELEASE</spring.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>3.8.1</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-core</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-beans</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-aop</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-expression</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>commons-logging</groupId>
            <artifactId>commons-logging</artifactId>
            <version>1.2</version>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-jar-plugin</artifactId>
                <version>2.3.1</version>
                <configuration>
                    <archive>
                        <manifest>
                            <!--運(yùn)行jar包時(shí)運(yùn)行的主類,要求類全名-->
                            <mainClass>com.hafiz.Runner</mainClass>
                            <!-- 是否指定項(xiàng)目classpath下的依賴 -->
                            <addClasspath>true</addClasspath>
                            <!-- 指定依賴的時(shí)候聲明前綴 -->
                            <classpathPrefix>./lib/</classpathPrefix>
                            <!--依賴是否使用帶有時(shí)間戳的唯一版本號(hào),如:xxx-1.3.0-20121225.012733.jar-->
                            <useUniqueVersions>false</useUniqueVersions>
                        </manifest>
                    </archive>
                </configuration>
            </plugin>
            <!--把當(dāng)前項(xiàng)目所有的依賴打包到target目錄下的lib文件夾下-->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-dependency-plugin</artifactId>
                <executions>
                    <execution>
                        <id>copy</id>
                        <phase>package</phase>
                        <goals>
                            <goal>copy-dependencies</goal>
                        </goals>
                        <configuration>
                            <outputDirectory>${project.build.directory}/lib</outputDirectory>
                            <!--已存在的Release版本不重復(fù)copy-->
                            <overWriteReleases>false</overWriteReleases>
                            <!--已存在的SnapShot版本不重復(fù)copy-->
                            <overWriteSnapshots>false</overWriteSnapshots>
                            <!--不存在或者有更新版本的依賴才copy-->
                            <overWriteIfNewer>true</overWriteIfNewer>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
</project>

我們現(xiàn)在進(jìn)入生成的jar包所在的文件夾下,使用 java -jar xxx.jar來(lái)執(zhí)行生成的jar包

到此我們就完成了如何使用maven的jar包生成插件來(lái)進(jìn)行生成指定依賴的可執(zhí)行jar包。

代碼Github地址:https://github.com/hafizzhang/assembly-demo.git

參考網(wǎng)址:

https://blog.csdn.net/xiao__gui/article/details/47341385

http://www.cnblogs.com/hafiz/p/6538107.html

https://www.cnblogs.com/hafiz/p/6538332.html

到此這篇關(guān)于Maven將代碼及依賴打成一個(gè)Jar包的方式的文章就介紹到這了,更多相關(guān)maven將依賴打入jar包內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • jdbcTemplate使用方法實(shí)例解析

    jdbcTemplate使用方法實(shí)例解析

    這篇文章主要介紹了jdbcTemplate使用方法實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • java多線程中線程封閉詳解

    java多線程中線程封閉詳解

    在本文里我們給大家分享了關(guān)于java多線程中線程封閉的知識(shí)點(diǎn)內(nèi)容以及用法,有需要讀者們可以參考下。
    2019-07-07
  • Java使用NIO優(yōu)化IO實(shí)現(xiàn)文件上傳下載功能

    Java使用NIO優(yōu)化IO實(shí)現(xiàn)文件上傳下載功能

    IO 是基于流來(lái)讀取的,而NIO則是基于塊讀取,面向流 的 I/O 系統(tǒng)一次一個(gè)字節(jié)地處理數(shù)據(jù),這篇文章主要介紹了Java使用NIO優(yōu)化IO實(shí)現(xiàn)文件上傳下載功能,需要的朋友可以參考下
    2022-07-07
  • java實(shí)現(xiàn)音頻文件播放功能

    java實(shí)現(xiàn)音頻文件播放功能

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)音頻文件播放功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • SpringBoot登錄驗(yàn)證token攔截器的實(shí)現(xiàn)

    SpringBoot登錄驗(yàn)證token攔截器的實(shí)現(xiàn)

    本文主要介紹了SpringBoot登錄驗(yàn)證token攔截器的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • Java中的CopyOnWriteArrayList解析

    Java中的CopyOnWriteArrayList解析

    這篇文章主要介紹了Java中的CopyOnWriteArrayList解析,ArrayList是非線程安全的,也就是說(shuō)在多個(gè)線程下進(jìn)行讀寫,會(huì)出現(xiàn)異常,既然是非線程安全,那我們就使用一些機(jī)制把它變安全不就好了,需要的朋友可以參考下
    2023-12-12
  • java繪制國(guó)際象棋與中國(guó)象棋棋盤

    java繪制國(guó)際象棋與中國(guó)象棋棋盤

    這篇文章主要為大家詳細(xì)介紹了java繪制國(guó)際象棋與中國(guó)象棋棋盤,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • Java Boolean 初始化方式詳解

    Java Boolean 初始化方式詳解

    這篇文章主要介紹了Java Boolean 初始化方式詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • java實(shí)現(xiàn)桌球游戲

    java實(shí)現(xiàn)桌球游戲

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)桌球游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • 淺談java中OO的概念和設(shè)計(jì)原則(必看)

    淺談java中OO的概念和設(shè)計(jì)原則(必看)

    下面小編就為大家?guī)?lái)一篇淺談java中OO的概念和設(shè)計(jì)原則(必看)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05

最新評(píng)論