意外异常:java.lang.NoClassDefFoundError:org / apache / log4j / LogManager

时间:2014-10-13 10:58:20

标签: java eclipse gwt jar

我正在开发一个GWT应用程序。它使用RPC从内部系统收集信息。它通过使用库jar来实现,我们称之为alpha.jar。我们在很多应用程序中都使用这个jar,所以它工作正常,并且它是在日食之外用ANT构建的。

alpha.jar中的一些类引用了LOG4J2以及许多其他外部jar,所以当我们运行一个应用程序时,我们将类路径传递给所有这些,并且一切正常。请注意,这不是一个简单的初学者问题。 alpha.jar正常工作,包括调用Log4J。

问题:

在Eclipse中,我有这个GWT应用程序项目以及Alpha.jar项目(当然还有源代码)。服务器部分需要实例化alpha对象并与alpha系统通信。

当通过向Alpha项目添加构建路径引用在GWT中执行此操作时,我的GWT应用程序运行良好。

当我代替项目引用include(在war / WEB-INF / lib中)alpha.jar并运行应用程序时,我第一次从alpha.jar实例化一个类时,我在标题中得到错误。 / p>

alpha.jar的构建方式没有什么特点,所以基本上它应该与eclipse中的项目相同,对吧?

请注意以下事项:

*)alpha.jar的依赖jar也在war / WEB-INF / lib中。 log4j2-core,log4j-api以及其他一些(例如apache)

*)如果我删除alpha.jar(以及调用它的代码)而只是添加名为LOG4J2的代码,那么该代码也可以正常工作!

为什么我在使用JAR时会遇到这个奇怪的错误?还要注意NoClassDefFoundError,它不是更常见的ClassNotFoundException。请参阅What causes and what are the differences between NoClassDefFoundError and ClassNotFoundException?

如果您需要更多信息,请与我们联系。

3 个答案:

答案 0 :(得分:12)

org.apache.log4j.LogManager是来自log4j 1.2的一个类(不是log4j2)。

因此,您的某个Web应用程序jar必须引用它。罪魁祸首应该在堆栈跟踪中可见。

根据您的具体情况,您可能只想将一个log4j 1.2 jar添加到Web应用程序中,因为这两个版本完全相互独立。

答案 1 :(得分:0)

如果您使用log4j 2,请不要忘记将log4 j2 .xml命名为log4j.xml

答案 2 :(得分:0)

如前所述:

org.apache.log4j.LogManager是log4j 1.2中的类(不是log4j2)。

当您结合使用log4j 1.2和log4j 2.x时,可能会遇到此问题。因此您必须将Bridge api添加到您的项目中。

这是一个Migrating问题。

将这些添加到您的pom.xml

        <log4j2.version>2.7</log4j2.version>
        <disruptor.version>3.3.6</disruptor.version>

        <!--log4j2 dependencies -->
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-api</artifactId>
            <version>${log4j2.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-core</artifactId>
            <version>${log4j2.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-1.2-api</artifactId>
            <version>${log4j2.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-slf4j-impl</artifactId>
            <version>${log4j2.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-jcl</artifactId>
            <version>${log4j2.version}</version>
        </dependency>
        <dependency>
            <groupId>com.lmax</groupId>
            <artifactId>disruptor</artifactId>
            <version>${disruptor.version}</version>
        </dependency>

然后,您可以使用mvn dependency:resolve查看没有log4j 1.2

[INFO] The following files have been resolved:
[INFO]    org.springframework.data:spring-data-redis:jar:1.7.2.RELEASE:compile
[INFO]    org.apache.logging.log4j:log4j-api:jar:2.7:compile
[INFO]    org.apache.logging.log4j:log4j-slf4j-impl:jar:2.7:compile
[INFO]    com.lmax:disruptor:jar:3.3.6:compile
[INFO]    org.apache.logging.log4j:log4j-1.2-api:jar:2.7:compile
[INFO]    javax.mail:mail:jar:1.4.5:compile
[INFO]    org.springframework:spring-tx:jar:4.3.1.RELEASE:compile
[INFO]    org.apache.logging.log4j:log4j-core:jar:2.7:compile
[INFO]    org.apache.logging.log4j:log4j-jcl:jar:2.7:compile
[INFO]    javax.activation:activation:jar:1.1:compile
[INFO]    org.springframework:spring-beans:jar:4.3.1.RELEASE:compile
[INFO]    org.springframework:spring-web:jar:4.3.1.RELEASE:compile
[INFO]    org.springframework:spring-webmvc:jar:4.3.1.RELEASE:compile
[INFO]    org.springframework:spring-oxm:jar:4.2.6.RELEASE:compile
[INFO]    org.springframework:spring-jdbc:jar:4.3.1.RELEASE:compile
[INFO]    com.alibaba:fastjson:jar:1.2.4:compile
[INFO]    mysql:mysql-connector-java:jar:5.1.21:compile
[INFO]    org.apache.tomcat:tomcat-servlet-api:jar:7.0.54:provided
[INFO]    org.slf4j:slf4j-api:jar:1.7.21:compile
[INFO]    org.springframework:spring-context-support:jar:4.3.1.RELEASE:compile
[INFO]    commons-beanutils:commons-beanutils:jar:1.8.3:compile
[INFO]    org.springframework:spring-context:jar:4.3.1.RELEASE:compile
[INFO]    org.hamcrest:hamcrest-core:jar:1.3:test
[INFO]    redis.clients:jedis:jar:2.8.1:compile
[INFO]    org.springframework:spring-expression:jar:4.3.1.RELEASE:compile
[INFO]    org.springframework.data:spring-data-commons:jar:1.12.2.RELEASE:compile
[INFO]    org.springframework.data:spring-data-keyvalue:jar:1.1.2.RELEASE:compile
[INFO]    junit:junit:jar:4.12:test
[INFO]    org.springframework:spring-core:jar:4.3.1.RELEASE:compile
[INFO]    commons-logging:commons-logging:jar:1.2:compile
[INFO]    org.springframework:spring-aop:jar:4.3.1.RELEASE:compile
[INFO]    org.apache.commons:commons-pool2:jar:2.4.2:compile
[INFO]    org.slf4j:jcl-over-slf4j:jar:1.7.21:runtime

引用: