java 具有 Maven 依赖性的 NoClassDefFoundError (log4j)
java NoClassDefFoundError with maven dependency (log4j)
我正在尝试使用 maven 编写一个小程序。我正在使用我大学教授的模板,我想使用 log4j 进行日志记录。
当我 运行 eclipse 中的程序时,它工作正常。但是,当我使用 "mvn install" 创建 jar 并尝试 运行 cmd 中的程序时,我得到一个 NoClassDefFoundError
C:\eclipse_workspace_buchhaltung\Buchhaltung\target>c:\jdk-11.0.4\bin\java.exe -jar Buchhaltung-1.0.0-SNAPSHOT.jar
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/logging/log4j/LogManager
at ch.hslu.demo.DemoKlasse.<clinit>(DemoKlasse.java:11)
Caused by: java.lang.ClassNotFoundException: org.apache.logging.log4j.LogManager
at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:583)
at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:178)
at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:521)
... 1 more
我用来尝试的 DemoKlasse 如下所示:
package ch.hslu.demo;
import java.time.LocalDateTime;
import java.util.Scanner;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
public class DemoKlasse {
private static final Logger logger = LogManager.getLogger(DemoKlasse.class); // that's line 11
public static void main(String[] args) {
logger.info("DemoKlasse gestartet: " + LocalDateTime.now());
System.out.println("Dies ist eine Testklasse!");
String eingabe = "";
Scanner sc = new Scanner(System.in);
while(true) {
System.out.println("Bitte geben Sie etwas ein. Beenden mit \"exit\"");
eingabe = sc.nextLine();
logger.info("Eingabe lautet: " + eingabe);
if(eingabe.equalsIgnoreCase("exit")) {
System.out.println("Das Programm wird beendet");
logger.info("Exit wurde eingegeben: " + LocalDateTime.now());
sc.close();
System.exit(1);
}
}
}
}
我的带有 log4j 部分的 pom 如下所示:
<properties>
...
<log4j2.version>2.12.1</log4j2.version>
<junit5.version>5.5.1</junit5.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>${log4j2.version}</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>${log4j2.version}</version>
<scope>runtime</scope>
</dependency>
...
我在这里也找到了这个:NoClassDefFoundError on Maven dependency
我尝试使用 maven-shade-plugin 和 maven-assembly-plugin,但仍然无法正常工作。
有谁知道为什么我不能使这么简单的程序工作?
你在做什么?
您正在创建一个包含您的代码的 JAR 文件(以及一个指向主 class 的清单文件)。
有什么问题?
您正在将代码导出到 JAR 文件,但未导出依赖项。显然,您的程序需要 运行 的依赖项(日志库不是必需的,但其他库是)。
如何解决?
你说,你试过shadow和assembly插件。您可以添加两者的依赖项。我认为您只是配置不正确。
对于 maven-assembly-plugin
,您需要创建一个 jar-with-dependencies
并且您不应该忘记您的主要 class。
例如,您可以使用以下配置(将 fully-qualified-main-class
替换为您的主包名称 class 后跟主包名称 class(以点分隔) :
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<configuration>
<archive>
<manifest>
<mainClass>fully.qualified.MainClass</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>
之后,您可以使用命令 mvn package
.
创建 JAR
确保执行 jar-with-dependencies
而不是 maven-jar-plugin
创建的 JAR。
其他可能的问题
您的程序可能在 provided
范围内声明了 log4j。在这种情况下,log4j 不包含在您的 jar-with-dependencies
.
中
见
我正在尝试使用 maven 编写一个小程序。我正在使用我大学教授的模板,我想使用 log4j 进行日志记录。 当我 运行 eclipse 中的程序时,它工作正常。但是,当我使用 "mvn install" 创建 jar 并尝试 运行 cmd 中的程序时,我得到一个 NoClassDefFoundError
C:\eclipse_workspace_buchhaltung\Buchhaltung\target>c:\jdk-11.0.4\bin\java.exe -jar Buchhaltung-1.0.0-SNAPSHOT.jar
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/logging/log4j/LogManager
at ch.hslu.demo.DemoKlasse.<clinit>(DemoKlasse.java:11)
Caused by: java.lang.ClassNotFoundException: org.apache.logging.log4j.LogManager
at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:583)
at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:178)
at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:521)
... 1 more
我用来尝试的 DemoKlasse 如下所示:
package ch.hslu.demo;
import java.time.LocalDateTime;
import java.util.Scanner;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
public class DemoKlasse {
private static final Logger logger = LogManager.getLogger(DemoKlasse.class); // that's line 11
public static void main(String[] args) {
logger.info("DemoKlasse gestartet: " + LocalDateTime.now());
System.out.println("Dies ist eine Testklasse!");
String eingabe = "";
Scanner sc = new Scanner(System.in);
while(true) {
System.out.println("Bitte geben Sie etwas ein. Beenden mit \"exit\"");
eingabe = sc.nextLine();
logger.info("Eingabe lautet: " + eingabe);
if(eingabe.equalsIgnoreCase("exit")) {
System.out.println("Das Programm wird beendet");
logger.info("Exit wurde eingegeben: " + LocalDateTime.now());
sc.close();
System.exit(1);
}
}
}
}
我的带有 log4j 部分的 pom 如下所示:
<properties>
...
<log4j2.version>2.12.1</log4j2.version>
<junit5.version>5.5.1</junit5.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>${log4j2.version}</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>${log4j2.version}</version>
<scope>runtime</scope>
</dependency>
...
我在这里也找到了这个:NoClassDefFoundError on Maven dependency 我尝试使用 maven-shade-plugin 和 maven-assembly-plugin,但仍然无法正常工作。
有谁知道为什么我不能使这么简单的程序工作?
你在做什么?
您正在创建一个包含您的代码的 JAR 文件(以及一个指向主 class 的清单文件)。
有什么问题?
您正在将代码导出到 JAR 文件,但未导出依赖项。显然,您的程序需要 运行 的依赖项(日志库不是必需的,但其他库是)。
如何解决?
你说,你试过shadow和assembly插件。您可以添加两者的依赖项。我认为您只是配置不正确。
对于 maven-assembly-plugin
,您需要创建一个 jar-with-dependencies
并且您不应该忘记您的主要 class。
例如,您可以使用以下配置(将 fully-qualified-main-class
替换为您的主包名称 class 后跟主包名称 class(以点分隔) :
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<configuration>
<archive>
<manifest>
<mainClass>fully.qualified.MainClass</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>
之后,您可以使用命令 mvn package
.
确保执行 jar-with-dependencies
而不是 maven-jar-plugin
创建的 JAR。
其他可能的问题
您的程序可能在 provided
范围内声明了 log4j。在这种情况下,log4j 不包含在您的 jar-with-dependencies
.
见