【问题标题】:Jar files inside another jar error NoClassDefFoundError and ClassNotFoundException另一个 jar 中的 jar 文件错误 NoClassDefFoundError 和 ClassNotFoundException
【发布时间】:2026-01-24 11:35:01
【问题描述】:

我创建了包含依赖 jar 的 jar 文件,但是当我尝试在其中运行类文件时,它给出了错误

Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/log4j/Logger
        at com.TestFlowProcessor.<clinit>(WebMethodsFlowProcessor.java:37)
Caused by: java.lang.ClassNotFoundException: org.apache.log4j.Logger
        at java.net.URLClassLoader.findClass(Unknown Source)
        at java.lang.ClassLoader.loadClass(Unknown Source)
        at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
        at java.lang.ClassLoader.loadClass(Unknown Source)

我的清单文件:

Manifest-Version: 1.0
Archiver-Version: Plexus Archiver
Created-By: Apache Maven
Built-By: test
Build-Jdk: 1.8.0_45
Class-Path: log4j-1.2.17.jar slf4j-api-1.7.10.jar commons-logging-1.1.jar dom4j-1.6.1.jar jsoup-1.8.3.jar junit-3.8.1.jar log4j-1.2.17.jar poi-3.8-20120326.jar poi-ooxml-3.8-20120326.jar poi-ooxml-schemas-3.8-20120326.jar SAPIntegrationDirectory.jar stax-api-1.0.1.jar xmlbeans-2.3.0.jar
Main-Class: com.TestFlowProcessor

我正在尝试使用 java -cp WMTOFuse.jar com.TestFlowProcessor

【问题讨论】:

  • 一般来说,类加载器不会加载嵌入在jar中的jar。您可以查看 OneJar 项目以获得可能的解决方案
  • 您可以将依赖的 jar 保存在一个文件夹中(例如 lib),而不是制作一个“胖”jar 文件,然后使用 java -cp /lib*:WMTOFuse.jar com.TestFlowProcessor .改成 ;如果在 Windows 中。

标签: java maven ant


【解决方案1】:

您可以为此使用“Ant”“jar”任务。参考https://ant.apache.org/manual/Tasks/jar.html

<jar destfile="build/main/checksites.jar">
    <fileset dir="build/main/classes"/>
    <restrict>
     <name name="**/*.class"/>
     <archives>
       <zips>
         <fileset dir="lib/main" includes="**/*.jar"/>
       </zips>
     </archives>
    </restrict>
    <manifest>
      <attribute name="Main-Class"
            value="com.acme.checksites.Main"/>
    </manifest>
  </jar>

上面创建了一个包含多个 jar 内容的单个 jar 文件。

【讨论】:

    【解决方案2】:

    问题似乎出在 log4j-1.2.17.jar 上。我已将其更改为 log4j-1.2.15.jar 和上述问题已解决。感谢大家 帮助我解决这个问题。

    【讨论】:

      最近更新 更多