-
Maven打jar包的三种方式(小结)
2020-08-18 23:03:07主要介绍了Maven打jar包的三种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 -
Maven打jar包的三种方式
2020-05-20 19:23:25目录不包含依赖jar包将依赖jar包输出到指定目录将项目依赖和项目打成一个jar包 不包含依赖jar包 该方法打包的jar,不包含依赖的jar包,也没有指定入口类。 <build> <plugins> <plugin> <!--...不包含依赖jar包
该方法打包的jar,不包含依赖的jar包,也没有指定入口类。
<build> <plugins> <plugin> <!-- 指定项目编译时的java版本和编码方式 --> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.7.0</version> <configuration> <target>1.8</target> <source>1.8</source> <encoding>UTF-8</encoding> </configuration> </plugin> </plugins> </build>
将依赖jar包输出到指定目录
该方法打包的jar,指定了入口类,可以直接使用
java \-jar project.jar
执行,
但是第三方依赖存在一个指定的外部目录下,迁移时需将jar和依赖目录一起迁移。<build> <plugins> <plugin> <!-- 指定项目编译时的java版本和编码方式 --> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.7.0</version> <configuration> <target>1.8</target> <source>1.8</source> <encoding>UTF-8</encoding> </configuration> </plugin> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-jar-plugin</artifactId> <version>3.1.0</version> <configuration> <archive> <manifest> <mainClass>com.netty.client.SignalClient</mainClass> <!-- 指定入口类 --> <addClasspath>true</addClasspath> <!-- 在jar的MF文件中生成classpath属性 --> <classpathPrefix>lib/</classpathPrefix> <!-- classpath前缀,即依赖jar包的路径 --> </manifest> </archive> </configuration> </plugin> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-dependency-plugin</artifactId> <version>3.1.1</version> <executions> <execution> <id>copy</id> <phase>install</phase> <goals> <goal>copy-dependencies</goal> </goals> <configuration> <!-- 指定依赖包的输出路径,需与上方的classpathPrefix保持一致 --> <outputDirectory>${project.build.directory}/lib</outputDirectory> </configuration> </execution> </executions> </plugin> </plugins> </build>
将项目依赖和项目打成一个jar包
该方法打包的jar,指定了入口类,可以直接使用
java \-jar project.jar
执行,
并且将第三方依赖打到了项目jar包中。<build> <plugins> <plugin> <!-- 指定项目编译时的java版本和编码方式 --> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.7.0</version> <configuration> <target>1.8</target> <source>1.8</source> <encoding>UTF-8</encoding> </configuration> </plugin> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-assembly-plugin</artifactId> <version>3.1.0</version> <configuration> <archive> <manifest> <mainClass>com.netty.client.SignalClient</mainClass> <!-- 指定入口类路径 --> </manifest> </archive> <descriptorRefs> <descriptorRef>jar-with-dependencies</descriptorRef> <!-- jar包后缀,生成的jar包形式为:project-1.0-SNAPSHOT-jar-with-dependencies.jar --> </descriptorRefs> </configuration> <!-- 添加此项后,可直接使用mvn package | mvn install --> <!-- 不添加此项,需直接使用mvn package assembly:single --> <executions> <execution> <id>make-assembly</id> <phase>package</phase> <goals> <goal>single</goal> </goals> </execution> </executions> </plugin> </plugins> </build>
-
maven打jar包的三种方式
2018-08-29 19:40:12Maven打包的三种方式 Maven可以使用mvn package指令对项目进行打包,如果使用Java -jar xxx.jar执行运行jar文件,会出现"no main manifest attribute, in xxx.jar"(没有设置Main-Class)、...Maven打包的三种方式
Maven可以使用mvn package指令对项目进行打包,如果使用Java -jar xxx.jar执行运行jar文件,会出现"no main manifest attribute, in xxx.jar"(没有设置Main-Class)、ClassNotFoundException(找不到依赖包)等错误。
要想jar包能直接通过java -jar xxx.jar运行,需要满足:
1、在jar包中的META-INF/MANIFEST.MF中指定Main-Class,这样才能确定程序的入口在哪里;
2、要能加载到依赖包。
使用Maven有以下几种方法可以生成能直接运行的jar包,可以根据需要选择一种合适的方法。
方法一:使用maven-jar-plugin和maven-dependency-plugin插件打包
在pom.xml中配置:
[html] view plain copy
- <build>
- <plugins>
- <plugin>
- <groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-jar-plugin</artifactId>
- <version>2.6</version>
- <configuration>
- <archive>
- <manifest>
- <addClasspath>true</addClasspath>
- <classpathPrefix>lib/</classpathPrefix>
- <mainClass>com.xxg.Main</mainClass>
- </manifest>
- </archive>
- </configuration>
- </plugin>
- <plugin>
- <groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-dependency-plugin</artifactId>
- <version>2.10</version>
- <executions>
- <execution>
- <id>copy-dependencies</id>
- <phase>package</phase>
- <goals>
- <goal>copy-dependencies</goal>
- </goals>
- <configuration>
- <outputDirectory>${project.build.directory}/lib</outputDirectory>
- </configuration>
- </execution>
- </executions>
- </plugin>
- </plugins>
- </build>
maven-jar-plugin用于生成META-INF/MANIFEST.MF文件的部分内容,<mainClass>com.xxg.Main</mainClass>指定MANIFEST.MF中的Main-Class,<addClasspath>true</addClasspath>会在MANIFEST.MF加上Class-Path项并配置依赖包,<classpathPrefix>lib/</classpathPrefix>指定依赖包所在目录。
例如下面是一个通过maven-jar-plugin插件生成的MANIFEST.MF文件片段:
[plain] view plain copy
- Class-Path: lib/commons-logging-1.2.jar lib/commons-io-2.4.jar
- Main-Class: com.xxg.Main
只是生成MANIFEST.MF文件还不够,maven-dependency-plugin插件用于将依赖包拷贝到<outputDirectory>${project.build.directory}/lib</outputDirectory>指定的位置,即lib目录下。
配置完成后,通过mvn package指令打包,会在target目录下生成jar包,并将依赖包拷贝到target/lib目录下,目录结构如下:
指定了Main-Class,有了依赖包,那么就可以直接通过java -jar xxx.jar运行jar包。
这种方式生成jar包有个缺点,就是生成的jar包太多不便于管理,下面两种方式只生成一个jar文件,包含项目本身的代码、资源以及所有的依赖包。
方法二:使用maven-assembly-plugin插件打包
在pom.xml中配置:
[html] view plain copy
- <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>
打包方式:
[plain] view plain copy
- mvn package assembly:single
打包后会在target目录下生成一个xxx-jar-with-dependencies.jar文件,这个文件不但包含了自己项目中的代码和资源,还包含了所有依赖包的内容。所以可以直接通过java -jar来运行。
此外还可以直接通过mvn package来打包,无需assembly:single,不过需要加上一些配置:
[html] view plain copy
- <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>
- <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>即表示在执行package打包时,执行assembly:single,所以可以直接使用mvn package打包。不过,如果项目中用到spring Framework,用这种方式打出来的包运行时会出错,使用下面的方法三可以处理。
方法三:使用maven-shade-plugin插件打包
在pom.xml中配置:
[html] view plain copy
- <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>
配置完成后,执行mvn package即可打包。在target目录下会生成两个jar包,注意不是original-xxx.jar文件,而是另外一个。和maven-assembly-plugin一样,生成的jar文件包含了所有依赖,所以可以直接运行。如果项目中用到了Spring Framework,将依赖打到一个jar包中,运行时会出现读取XML schema文件出错。原因是Spring Framework的多个jar包中包含相同的文件spring.handlers和spring.schemas,如果生成一个jar包会互相覆盖。为了避免互相影响,可以使用AppendingTransformer来对文件内容追加合并:
[html] view plain copy
- <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包的三种方式
2019-07-12 09:20:31打包一共有三种方式 第一种方法,把所有的jar包都打进一个jar包里面 第二种方法,把jar包和所依赖的jar包分开打包 第三种方法,把所依赖的jar包独立生成到target目录下,运行时手动指定target目录 1.把所有的jar...参考链接:https://www.cnblogs.com/GarfieldEr007/p/6995525.html
打包一共有三种方式
第一种方法,把所有的jar包都打进一个jar包里面
第二种方法,把jar包和所依赖的jar包分开打包
第三种方法,把所依赖的jar包独立生成到target目录下,运行时手动指定target目录
1.把所有的jar包都打进一个jar包里面
用maven创建一个新工程
主类
package com.ai.oidd; import org.apache.commons.lang3.ClassUtils; public class test { public static void main(String[] args) { System.out.println(ClassUtils.isPrimitiveOrWrapper(Integer.class)); //true } }
Pom配置文件
<?xml version="1.0" encoding="UTF-8"?> <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.ctc</groupId> <artifactId>mavenTest</artifactId> <version>1.0-SNAPSHOT</version> <dependencies> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.9</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-jar-plugin</artifactId> <configuration> <archive> <manifest> <mainClass>com.ai.oidd.test</mainClass> </manifest> </archive> </configuration> </plugin> </plugins> </build> </project>
接下来使用mvn package进行打包,用java -jar mavenTest-1.0-SNAPSHOT.jar进行运行
2.分开打包
把所有外部依赖的包都打一个包
用maven创建一个新工程
工程名为JarWithDependency
(1)创建一个main类
package com.ai.oidd; import org.apache.commons.lang3.ClassUtils; public class Test { public static void main(String[] args) { System.out.println(ClassUtils.isPrimitiveOrWrapper(Integer.class)); //true System.out.println("hello"); } }
(2)pom配置文件
<?xml version="1.0" encoding="UTF-8"?> <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</groupId> <artifactId>JarWithDependency</artifactId> <version>1.0-SNAPSHOT</version> <dependencies> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.9</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-jar-plugin</artifactId> <configuration> <archive> <manifest> <mainClass>com.ai.oidd.Test</mainClass> </manifest> </archive> </configuration> </plugin> <plugin> <artifactId>maven-assembly-plugin</artifactId> <configuration> <descriptorRefs> <descriptorRef>jar-with-dependencies</descriptorRef> </descriptorRefs> </configuration> <executions> <execution> <id>make-assembly</id> <phase>package</phase> <goals> <goal>attached</goal> </goals> </execution> </executions> </plugin> </plugins> </build> </project>
(3)打包,会有两个jar包
cd进入target目录
java -cp JarWithDependency-1.0-SNAPSHOT-jar-with-dependencies.jar com.ai.oidd.Test
第一个为所依赖的jar包打成的一个jar包,第二个为主类地址
输出结果
3.把引用的jar包引入到classpath里面,以java -cp的方式允许
(1)先创建一个main类
package com.ai.oidd; import org.apache.commons.lang3.ClassUtils; public class Test { public static void main(String[] args) { System.out.println(ClassUtils.isPrimitiveOrWrapper(Integer.class)); //true System.out.println("hello"); } }
(2)pom文件
<?xml version="1.0" encoding="UTF-8"?> <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</groupId> <artifactId>JarWithDependency</artifactId> <version>1.0-SNAPSHOT</version> <dependencies> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.9</version> </dependency> </dependencies> <build> <sourceDirectory>src/main/java</sourceDirectory> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-jar-plugin</artifactId> <configuration> <archive> <manifest> <mainClass>com.ai.oidd.Test</mainClass> </manifest> </archive> </configuration> </plugin> <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} </outputDirectory> </configuration> </execution> </executions> </plugin> </plugins> </build> </project>
外部依赖的包分开来,不会一起打成jar包
cd到指定目录
java -cp JarWithDependency-1.0-SNAPSHOT.jar:commons-lang3-3.9.jar com.ai.oidd.Test
-
Maven的打包三种打包方式 jar,war,pom
2020-05-17 11:36:36Maven的打包三种打包方式-jar,war,pom 1.默认jar打包方式 maven的默认打包方式,不需要设置packaging来指定。 使用情况:通常是工具类项目(common)和需要被其他项目依赖的项目,打成jar包 2.war 需要设置<... -
Maven 打包 jar
2020-09-09 14:29:13Maven 常用的打包方式有三种 插件 功能 maven-jar-plugin maven 默认打包插件,用来创建 project jar maven-shade-plugin 打可执行包,executable(fat) jar maven-assembly-plugin 支持自定义打包方式 ... -
IDEA打jar包的三种方式
2019-04-03 18:19:51因为常常需要把jar包放在集群上运行,总结以下常用到的几种打jar包的方式 1、用IDEA自带的打包形式 2、用Maven插件maven-shade-plugin打包 3、用Maven插件maven-assembly-plugin打包 ... -
maven三种打包方式
2019-11-26 10:12:06当你使用 Maven 对项目打包时,你需要了解以下 3 个打包 plugin,它们分别是: plugin function ...用来打可执行包,executable(fat) jar maven-assembly-plugin 支持定制化打包方式,... -
maven的三种项目打包方式-jar,war,pom
2020-05-08 17:39:03maven的三种打包方式有何不同: 1.jar包(默认打包方式) 是maven的默认打包方式(不通过packaging来指定),通常是许多工具类项目(common)和需要被其他项目依赖的项目,打成jar包。 2.war包 会通过<packaging&... -
maven中pom、jar、war三种打包方式的区别
2021-01-17 15:33:261、pom打包方式可以作为其他项目的maven依赖,构建maven项目时可用在父级工程或者聚合工程中,用来做jar包的版本控制; 2、jar包通常是开发时需要应用的类,当需要某些功能时就导入相应的jar包,在构建maven时作为... -
Maven的三种打包方式
2021-02-23 09:06:32Maven的三种打包方式 打包的本质是压缩,而jar包和war包都是zip包。 1、pom是maven依赖文件 可以作为其他项目的maven依赖,用来做jar包的版本控制。 2、jar是java普通项目打包文件 通常是开发时需要应用的类,当需要... -
maven的三种打包方式
2020-10-12 19:56:11maven的三种打包方式 pom:是maven依赖文件 jar:是java普通项目打包 war:是java web项目打包。 pom: 打出来的可以作为其他项目的maven依赖,在工程A中添加工程B的pom,A就可以使用B中的类。用在父级工程或聚合... -
Maven 打包jar及依赖管理
2019-05-09 16:47:33maven提供的打包插件有如下三种: plugin function maven-jar-plugin maven 默认打包插件,用来创建 project jar maven-shade-plugin 用来打可执行包,executable(fat) jar maven-assembly-plugin ... -
项目打jar包的两种方式,一种可直接运行,一种可在maven库中作为依赖
2020-05-18 10:47:09一种是含第三方依赖的包,会比较大 可以直接在cmd中 java -jar xx.jar运行 直接使用idea的Terminal(终端)输入命令打包: mvn clean package -DskipTests(跳过测试类) (-P test 指定使用test环境的配置文件) 打包... -
springboot项目通过maven打包的三种方式
2021-03-11 16:10:21直接打SpringBoot的jar包 这种方式包含所需要的所有依赖jar包,体积较大,不便于部署服务器。 <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <... -
pom 的第三方jar报错_01_maven-将第三方jar包一起打包到项目 jar 包中
2020-12-30 19:19:23前言:maven-将依赖的 jar包一起打包...如果使用Maven默认的打包方式的话,打成项目jar包后,会导致其他第三方jar包无法找到的异常信息,报错ClassNotFoundException。以下有两种方法可以规避这个问题。一、在pom.xml ... -
maven构建的Springboot项目打jar包并运行在Linux的服务器上。
2020-11-30 12:18:11文章目录一、使用maven命令打jar包二、使用Xftp或其他工具把jar包扔到服务器上三、使用java -jar运行打好的jar包的三种方式1.前台运行。2.后台运行。3.记录程序运行日志。四、关闭运行的jar程序1.已知运行的端口号...