【问题标题】:NoClassDefFoundError: org/apache/log4j/LoggerNoClassDefFoundError: org/apache/log4j/Logger
【发布时间】:2018-01-30 06:38:58
【问题描述】:

我在我的 java 项目中使用了 log4j 记录器,并且在我的 pom.xml 中有以下内容:

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

我在名为“resources”的目录中添加了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(我猜还有一堆其他的 dep)添加到运行时类路径。 IE。 -cp java 选项
  • 我认为您在类路径中有多个 log4j 实现。我之前遇到过类似的问题。所以请检查一下。

标签: java maven logging intellij-idea log4j


【解决方案1】:

这是因为您只是在没有依赖 jar 的情况下运行您的 jar。您需要使用 -cp 命令在类路径中添加所有依赖项。

另一种选择是使用maven-shade-plugin 创建一个“Fat” jar,在同一个 jar 中包含相关的 java 类。这使得使用命令行运行 jar 变得相当简单。要使用它,只需将以下 sn-p 添加到您的 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>

注意:请在&lt;ENTER_YOUR_MAINCLASS_HERE&gt;适当地替换你的jar的主类

如果您确实认为多次包含不同版本存在相同依赖项的问题,那么您应该使用

mvn dependency:tree

命令获取正在复制的库的详细信息,然后从您的依赖项中删除其中一个版本。

【讨论】:

    【解决方案2】:

    请在清理您的 ma​​ven 存储库后尝试,有时它会选择多个版本的相同 jar。

    【讨论】:

    • 我使用dependency:purge-local-repository clean install构建然后尝试但错误仍然存​​在。
    • 请删除您的 maven 存储库文件夹(如果不完整则仅删除 log4j 文件夹),命令参数有时无法正常工作
    【解决方案3】:

    这是 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
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2014-12-15
    • 2020-04-12
    • 2021-02-15
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多