我在我的java应用程序中使用log4j 2.3。我通过maven添加了依赖项。
在eclipse中运行程序时,一切正常,但是当我用maven打包它并尝试运行jar我得到以下错误:
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache logging/log4j/LogManager
at main.myclass.<clinit>(myclass.java:11)
Caused by: java.lang.ClassNotFoundException: org.apache.logging.log4j.LogManager
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)
... 1 more
为什么从jar运行时找不到类?
添加log4j 1.2
也不起作用。该程序在eclipse中运行良好,因此不应该缺少依赖项。
当您从命令行运行应用程序jar时,您的依赖jar在运行时不可用。您需要将这两个插件中的任何一个包含到pom. xml中,以便您的依赖项在运行时可用。
使用:maven-shad-plugin
<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>org.sonatype.haven.HavenCli</mainClass>
</transformer>
</transformers>
</configuration>
</execution>
</executions>
</plugin>
使用:maven-依赖-插件
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<version>2.8</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>
当您执行mvn包时,它将生成uberjar/或将依赖项复制到outputDirectory。我更喜欢maven-shad-plugin生成一个jar所有依赖项。
请将jar文件添加到库中的类路径,它对我有用
安装最新版本的log4j
(我已经安装了log4j-2.3.jar
)。
并按照以下步骤操作:
对我很管用