NoClassDefFoundError: org/apache/log4j/Logger

3

我在我的Java项目中使用了log4j日志记录器,并在我的pom.xml文件中包含以下内容:

<dependencies>
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.17</version>
    </dependency>
</dependencies>

我已将log4j.properties添加到名为“资源”的目录中,并将其作为intelliJ项目结构中的源代码添加。当我构建该项目时,它能够成功构建。但是,当我尝试通过运行java -jar myproject.jar来运行jar文件时,会出现以下错误。
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/log4j/Logger
    at org.wso2.confvalidator.ConfigValidator.<clinit>(ConfigValidator.java:40)
Caused by: java.lang.ClassNotFoundException: org.apache.log4j.Logger
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:335)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 1 more

请确保将log4j jar(以及其他一堆依赖项)添加到运行时类路径中。即-cp java选项。 - gtosto
我认为你的类路径中有多个log4j的实现。我之前也遇到过类似的问题。所以请检查一下。 - Prasad
3个回答

1
这是因为您仅运行了JAR文件,而没有依赖的JAR文件。您需要使用-cp命令将所有依赖项添加到类路径中。
另一种选择是使用maven-shade-plugin创建一个包含相同JAR文件中的依赖Java类的"Fat" JAR文件。这使得使用命令行运行JAR文件非常简单。要使用它,请在pom插件部分中添加以下片段:
<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-shade-plugin</artifactId>
    <version>3.0.0</version>
    <configuration>
        <createDependencyReducedPom>false</createDependencyReducedPom>
        <filters>
            <filter>
                <artifact>*:*</artifact>
                <excludes>
                    <exclude>META-INF/*.SF</exclude>
                    <exclude>META-INF/*.DSA</exclude>
                    <exclude>META-INF/*.RSA</exclude>
                </excludes>
            </filter>
        </filters>
    </configuration>
    <executions>
        <execution>
            <phase>package</phase>
            <goals>
                <goal>shade</goal>
            </goals>
            <configuration>
                <transformers>
                    <transformer implementation="org.apache.maven.plugins.shade.resource.ServicesResourceTransformer" />
                    <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                        <mainClass><ENTER_YOUR_MAINCLASS_HERE></mainClass>
                        <manifestEntries>
                            <Class-Path>..</Class-Path>
                        </manifestEntries>
                    </transformer>

                    <transformer implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
                        <resource>META-INF/cxf/bus-extensions.txt</resource>
                    </transformer>

                </transformers>
            </configuration>
        </execution>
    </executions>
</plugin>

注意:请适当替换您的jar文件的主类,位置在<ENTER_YOUR_MAINCLASS_HERE> 如果您确实认为存在同一依赖项包含多个不同版本的问题,则应使用
mvn dependency:tree

使用命令获取重复的库细节,然后从依赖项中删除一个版本。

0
请尝试在 清理 您的 Maven 仓库 后重试,有时会选择同一 JAR 文件的多个版本。

我使用了 dependency:purge-local-repository clean install 进行构建,但是尝试后错误仍然存在。 - S.Dan
请删除您的Maven存储库文件夹(如果不是整个文件夹,则仅删除log4j文件夹),因为命令参数有时无法正常工作。 - Amir

-1

这是log4j 2版本的依赖项。请尝试使用它。

<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-api</artifactId>
    <version>2.10.0</version>
</dependency>

然后在构建时出现错误。 [ERROR] /home/sachithra/myproject/src/main/java/org/confvalidator/utils/XSDValidator.java:[20,24] package org.apache.log4j does not exist - S.Dan

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接