详解如何使用maven生成可以执行的jar

不依赖任何外界包,maven如何生成可以执行的jar?

pom中不包含任何引用的情况下,只需要在pom中添加 maven-jar-plugin即可。

解决过程

新建项目,仅包含一个main函数类:Xixi.java,输出 Xixi Say: hello

pom中配置为

<groupId>com.paxi</groupId>
 <artifactId>xixi</artifactId>
 <version>1.0-SNAPSHOT</version>
 <packaging>jar</packaging>

 <name>xixi</name>
 <url>http://maven.apache.org</url>

 <properties>
  <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
 </properties>

执行 mvn clean install 生成jar包 xixi-1.0-SNAPSHOT.jar,执行jar命令,执行反馈出错

 java -jar xixi-1.0-SNAPSHOT.jar
xixi-1.0-SNAPSHOT.jar中没有主清单属性

对jar进行解压缩jar xvf xixi-1.0-SNAPSHOT.jar查看对应文件MANIFEST.MF

 cat META-INF/MANIFEST.MF
Manifest-Version: 1.0
Archiver-Version: Plexus Archiver
Built-By: paxi
Created-By: Apache Maven 3.3.3
Build-Jdk: 1.8.0_121

在pom中添加插件 maven-jar-plugin

<build>
  <plugins>
   <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-jar-plugin</artifactId>
    <version>3.1.0</version>
    <configuration>
     <archive>
      <manifest>
       <mainClass>com.paxi.Xixi</mainClass>
      </manifest>
     </archive>
    </configuration>
   </plugin>
  </plugins>
 </build>

执行成功输出

java -jar xixi-1.0-SNAPSHOT.jar
Xixi Say: hello

再对解压缩后的MANIFEST.MF文件查看为

 cat META-INF/MANIFEST.MF
Manifest-Version: 1.0
Built-By: paxi
Created-By: Apache Maven 3.3.3
Build-Jdk: 1.8.0_121
Main-Class: com.paxi.Xixi //新增

在pom中添加依赖,maven如何生成可执行jar?

需要使用插件maven-dependency-plugin 和 maven-jar-plugin。

解决过程

在pom中仅仅增加一个apache-commons包

<groupId>com.paxi</groupId>
 <artifactId>xixi</artifactId>
 <version>1.0-SNAPSHOT</version>
 <packaging>jar</packaging>

 <name>xixi</name>
 <url>http://maven.apache.org</url>

 <properties>
  <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
 </properties>
 <dependencies>

   <dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-lang3</artifactId>
    <version>3.7</version>
  </dependency>

 </dependencies>

在代码中运用common包中的一个类

 public static void main(String[] args) {
    String words = "Xixi Say: hello";
    if (StringUtils.isNotBlank(words))
    {
      System.out.println(words);
    }
  }

打包后直接运行出错

java -jar xixi-1.0-SNAPSHOT.jar
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/lang3/StringUtils
    at com.paxi.Xixi.main(Xixi.java:11)
Caused by: java.lang.ClassNotFoundException: org.apache.commons.lang3.StringUtils
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 1 more

在pom中增加插件

<build>
  <plugins>
   <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-jar-plugin</artifactId>
    <version>3.1.0</version>
    <configuration>
     <archive>
      <manifest>
       <addClasspath>true</addClasspath>
       <mainClass>com.paxi.Xixi</mainClass>
       <classpathPrefix>libs/</classpathPrefix>
      </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-dependencies</id>
      <phase>package</phase>
      <goals>
       <goal>copy-dependencies</goal>
      </goals>
      <configuration>
       <outputDirectory>
        ${project.build.directory}/libs
       </outputDirectory>
      </configuration>
     </execution>
    </executions>
   </plugin>

  </plugins>
 </build>

再次运行

 java -jar xixi-1.0-SNAPSHOT.jar
Xixi Say: hello

MANIFEST.MF文件为

 cat META-INF/MANIFEST.MF
Manifest-Version: 1.0
Built-By: paxi
Class-Path: libs/commons-lang3-3.7.jar
Created-By: Apache Maven 3.3.3
Build-Jdk: 1.8.0_121
Main-Class: com.paxi.Xixi

不仅使用了POM中的依赖还使用了三方的jar,maven如何生成可执行jar?

编译过程需要对编译插件 maven-compiler-plugin做修改,运行的时候需要加上三方jar的目录,执行命令

 java -jar -Djava.ext.dirs=lib/ target/xixi-1.0-SNAPSHOT.jar
Xixi Say: hello
Papa say:hello

编译解决过程

测试代码为

 public static void main(String[] args) {
    String words = "Xixi Say: hello";
    if (StringUtils.isNotBlank(words))
    {
      System.out.println(words);
    }
    Papa.say();
  }

使用mvn命令执行报错

[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1:compile (default-compile) on project xixi: Compilation failure
xixi/src/main/java/com/paxi/Xixi.java:[15,9] 找不到符号

pom中添加编译插件

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <version>3.1</version>
    <configuration>
     <compilerArgs>
      <arg>-Djava.ext.dirs=lib/</arg>
     </compilerArgs>
    </configuration>
   </plugin>

打包执行

 java -jar target/xixi-1.0-SNAPSHOT.jar
Xixi Say: hello
Exception in thread "main" java.lang.NoClassDefFoundError: com/paxi/Papa
  at com.paxi.Xixi.main(Xixi.java:15)
Caused by: java.lang.ClassNotFoundException: com.paxi.Papa
  at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
  at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
  at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
  at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
  ... 1 more

加上参数后即可得出结果

 java -jar -Djava.ext.dirs=lib/ target/xixi-1.0-SNAPSHOT.jar
Xixi Say: hello
Papa say:hello

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Spring Boot Maven 打包可执行Jar文件的实现方法

    Maven pom.xml 必须包含 <packaging>jar</packaging> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <configuration> <fork>

  • 使用maven生成可执行的jar包的方法

    本文介绍了使用maven生成可执行的jar包的方法,分享给大家,具体如下: 从pom的xsi中可以打开描述pom的schema: 可以看到pom中,project的结构: 默认的mvn install生成的jar是不带主类入口的,需要在maven-compile-plugin中设置主类, <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSche

  • java 中使用maven shade plugin 打可执行Jar包

    java 中使用maven shade plugin 打可执行Jar包 eclipse里有一个功能叫做"打可执行(runnable) jar包", 用这个功能可以把一个工程自身和所有依赖包打成一个fat jar,并且指定Main方法,这样直接使用java jar xxx.jar就可以运行代码了. 但是在不使用eclipse的时候呢?其实,借助maven,我们很容易实现同样功能.maven提供了一个shade plugin,可以用来打fat jar, 同时也提供了指定main方法的功能.

  • 详解如何使用maven生成可以执行的jar

    不依赖任何外界包,maven如何生成可以执行的jar? pom中不包含任何引用的情况下,只需要在pom中添加 maven-jar-plugin即可. 解决过程 新建项目,仅包含一个main函数类:Xixi.java,输出 Xixi Say: hello pom中配置为 <groupId>com.paxi</groupId> <artifactId>xixi</artifactId> <version>1.0-SNAPSHOT</versio

  • 详解IDEA使用Maven项目不能加入本地Jar包的解决方法

    使用IDEA编辑Web项目已经逐渐超过了使用eclipse的人数,但是IDEA对于pom.xml的执行也就是Maven方式导包支持并不是很完善,简单来说就是pom.xml上面记录的依赖库一般都能导入,但是如果pom.xml上面的某个依赖库失效,比如远程服务器关闭或者网络不通,或者是你想要加入本地硬盘上的某个jar包而不修改pom.xml的时候,IDEA的弊端就会显现出来.主要表现就是无法获得的依赖库或者本地Jar包无法放到/WEB-INF/lib目录下,导致Web项目部署时报错. 一个常见的错误

  • 详解IOS开发中生成推送的pem文件

    详解IOS开发中生成推送的pem文件 具体步骤如下: 首先,需要一个pem的证书,该证书需要与开发时签名用的一致. 具体生成pem证书方法如下: 1. 登录到 iPhone Developer Connection Portal(http://developer.apple.com/iphone/manage/overview/index.action )并点击 App IDs 2. 创建一个不使用通配符的 App ID .通配符 ID 不能用于推送通知服务.例如,  com.itotem.ip

  • 详解使用zxing库生成QR-Code二维码

    详解使用zxing库生成QR-Code二维码 最近因为一些工作需要,需要根据实际的信息生成QR-Code二维码图片文件,自然想到zxing库了,具体的代码很简单,做个备忘. 首先是引入zxing库,我是使用maven构建项目的,添加依赖: <dependency> <groupId>com.google.zxing</groupId> <artifactId>javase</artifactId> <version>3.3.0<

  • 详解用Pytest+Allure生成漂亮的HTML图形化测试报告

    对于软件测试工作来说,测试报告是非常重要的工作产出.一个漂亮.清晰.格式规范.内容完整的测试报告,既能最大化我们的测试工作产出,又能够减少开发人员和测试人员的沟通成本. 本篇文章将介绍如何使用开源的测试报告生成框架Allure生成规范.格式统一.美观的测试报告. 通过这篇文章的介绍,你将能够: 将Allure与Pytest测试框架相结合: 如何定制化测试报告内容 执行测试之后,生成Allure格式的测试报告. 如何与Jenkins集成. 将测试环境信息展示到测试报告中. 1.Allure测试报告

  • 详解Linux动态库生成与使用指南

    Linux下动态库文件的文件名形如 libxxx.so,其中so是 Shared Object 的缩写,即可以共享的目标文件. 在链接动态库生成可执行文件时,并不会把动态库的代码复制到执行文件中,而是在执行文件中记录对动态库的引用. 程序执行时,再去加载动态库文件.如果动态库已经加载,则不必重复加载,从而能节省内存空间. Linux下生成和使用动态库的步骤如下: 编写源文件. 将一个或几个源文件编译链接,生成共享库. 通过 -L<path> -lxxx 的gcc选项链接生成的libxxx.so

  • 详解安装Eclipse Maven插件的几种方法

    昨天直接在机器上配置了Maven环境,今天顺便把Eclipse等IDE环境配置好. 安装IDE Plugins的方法有很多.其一:在线安装,通过Help-->Install New Software的方式,输入HTTP地址来安装,简单易操作,但是也优缺点,就是下载速度慢,或者有的时候干脆搜索不到要安装的插件.使用第一种方式来安装,输入 http 地址:http://m2eclipse.sonatype.org/sites/m2e,把选项勾上,然后等待它  下载安装,完成之后重启 eclipse

  • 详解Python 多线程 Timer定时器/延迟执行、Event事件

    Timer继承子Thread类,是Thread的子类,也是线程类,具有线程的能力和特征.这个类用来定义多久执行一个函数. 它的实例是能够延迟执行目标函数的线程,在真正执行目标函数之前,都可以cancel它. Timer源码: class Timer(Thread): def __init__(self, interval, function, args=None, kwargs=None): Thread.__init__(self) self.interval = interval self.

  • 详解如何使用git 生成patch 和打入patch

    平时我们在使用git 管理项目的时候,会遇到这样一种情况,那就是客户使用git 生成patch 给到我们,那我们就需要把客户给到patch 打入到我们的project ,基于这样一个场景,我把git 如何生成patch 和如何打入patch 做总结 生成patch 的方法:(我这里描述的生成patch 是根据commit 记录生成的) 1.例如首先先通过git log 查看有哪一些commit 2.把第一次commit 提交以后的(不包括第一次提交)都生成patch 如上图所示:使用命令:git

随机推荐