java - NoClassDefFoundError : org/apache/log4j/Logger

标签 java maven logging intellij-idea log4j

我在我的 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

最佳答案

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

另一种选择是使用 maven-shade-plugin创建一个“胖”jar,在同一个 jar 中包含依赖的 java 类。这使得使用命令行运行 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>

注意:请在 <ENTER_YOUR_MAINCLASS_HERE> 适本地替换你的 jar 的主类

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

mvn dependency:tree

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

关于java - NoClassDefFoundError : org/apache/log4j/Logger,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48515355/

相关文章:

java - 从 App Engine 模块内读取文件

maven-shade-plugin - 在类 org.apache.maven.plugins.shade.resource.ManifestResourceTransformer 中找不到 'resource'

java - log4j:错误 "org.apache.log4j.ConsoleAppender"对象不可分配给 "org.apache.log4j.Appender"变量

Python 日志记录 setLevel() 没有生效

java - Comparator 在内部使用哪种类型来比较值以及它如何调用其比较方法?

java - Web服务调用超时问题

java - 将数字缩放为 <= 255?

eclipse - 安装 m2e-egit 后发现 Eclipse IDE (Mars) 中缺少 Maven

logging - Akka slf4j 不工作

java - 在 Java 中创建树的最有效方法是什么?