gpt4 book ai didi

java - Web 环境 Spring/Wicket/Derby/Jetty 中 NoClassDefFoundError 错误的问题

转载 作者:行者123 更新时间:2023-12-02 09:46:10 24 4
gpt4 key购买 nike

我正在尝试构建一个简单的 JDBC Spring 模板应用程序,我使用的 web 框架是 wicket 并且在 jetty 6 web 服务器下(通过 Jetty Maven 插件)。另外,我正在使用 Eclipse 构建应用程序。

出于某种原因,我在使用 Derby jdbc 类时遇到了 NoClassDefFoundError。我假设我会得到一个 class not found 异常未找到,所以我猜测还有其他事情发生。 derby 类是类路径的一部分,即 WEB-INF/lib 目录。你认为问题是什么?

我对这个问题的看法:这不是“在类路径中找不到 jar”错误,而是 Java 或 spring 动态加载该类以及何时加载该类的问题。

我使用 Eclipse 作为开发工具,但这可能不是问题的一部分。我仍在命令行上使用 Maven 并遇到相同的问题。

这是错误:

WicketMessage:无法使用构造函数 public wicketspring.easy.HomePage() 实例化页面

根本原因:

java.lang.NoClassDefFoundError: Could not initialize class org.apache.derby.jdbc.EmbeddedDriver
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:169)
at org.apache.commons.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:1130)
at org.apache.commons.dbcp.BasicDataSource.getConnection(BasicDataSource.java:880)
at org.springframework.jdbc.datasource.DataSourceUtils.doGetConnection(DataSourceUtils.java:113)
at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.java:79)
at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:577)
at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:619)
at wicketspring.easy.jdbc.JdbcWicketSpringHandler.data(JdbcWicketSpringHandler.java:39)
at WICKET_wicketspring.easy.jdbc.JdbcWicketSpringHandler$$FastClassByCGLIB$$f1187cb6.invoke(<generated>)
at net.sf.cglib.proxy.MethodProxy.invoke(MethodProxy.java:191)
at org.apache.wicket.proxy.LazyInitProxyFactory$CGLibInterceptor.intercept(LazyInitProxyFactory.java:319)
at WICKET_wicketspring.easy.jdbc.JdbcWicketSpringHandler$$EnhancerByCGLIB$$e8f0e174.data(<generated>)
at wicketspring.easy.HomePage.<init>(HomePage.java:91)
at wicketspring.easy.HomePage.<init>(HomePage.java:47)

这是 Spring 的 applicationContext.xml:
<beans>
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="org.apache.derby.jdbc.EmbeddedDriver" />
<property name="url"><value>jdbc:derby:wicketspringdb</value></property>
<property name="username"><value></value></property>
<property name="password"><value></value></property>
</bean>
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource" />
</bean>
</beans>
<beans>
<import resource="classpath:common.xml"/>
<bean id="jdbcHandler" class=wicketspring.easy.jdbc.JdbcWicketSpringHandler">
<property name="jdbcTemplate" ref="jdbcTemplate" />
</bean>

</beans>


...
Another stack trace system out.

Page.java:74) - At [2b] -- java.lang.NoClassDefFoundError: Could not initialize class org.apache.derby.jdbc.EmbeddedDriver
java.lang.NoClassDefFoundError: Could not initialize class org.apache.derby.jdbc.EmbeddedDriver
at wicketspring.easy.HomePage.<init>(HomePage.java:72)
at wicketspring.easy.HomePage.<init>(HomePage.java:47)
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:
39)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorIm
pl.java:27)

...

这是java代码,代码编译,我可以打印出类,但我不能实例化它。奇怪的?

Java代码:
package wicketspring.easy;

import java.util.List;

import org.apache.wicket.Application;
import org.apache.wicket.PageParameters;
import org.apache.wicket.markup.html.WebPage;
import org.apache.wicket.markup.html.basic.Label;
import org.apache.wicket.markup.html.list.ListItem;
import org.apache.wicket.markup.html.list.ListView;
import org.apache.wicket.model.CompoundPropertyModel;
import org.apache.wicket.proxy.IProxyTargetLocator;
import org.apache.wicket.proxy.LazyInitProxyFactory;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import model.LoadableDetachableList;
import model.SelectionOptionBean;
import wicketspring.easy.jdbc.JdbcWicketSpringHandler;
import wicketspring.easy.service.IStateListService;
import wicketspring.easy.service.StateListServiceImpl;

import org.apache.derby.jdbc.EmbeddedDriver;

public class HomePage extends WebPage {

private final JdbcWicketSpringHandler jdbcWicketSpringHandler;

public HomePage(final PageParameters parameters) {

super(parameters);
jdbcWicketSpringHandler = (JdbcWicketSpringHandler) LazyInitProxyFactory.createProxy(JdbcWicketSpringHandler.class,
new IProxyTargetLocator() {
private static final long serialVersionUID = 1L;
public Object locateProxyTarget() {
return ((WicketApplication) Application.get()).context().getBean("jdbcHandler");
}
});

/// WEIRD BECAUSE IT REACHES THIS POINT!!!
LOGGER.debug("At [1] -- " + EmbeddedDriver.class);
try {
LOGGER.debug("At [2] -- " + new org.apache.derby.jdbc.EmbeddedDriver());
} catch (NoClassDefFoundError ne) {
// STACK TRACE ERROR HERE!!!!
LOGGER.debug("At [2b] -- " + ne);
ne.printStackTrace();
} catch (Exception e) {
LOGGER.debug("At [2] -- " + e);
e.printStackTrace();
}
try {

LOGGER.debug("At -- " + Class.forName("org.apache.derby.jdbc.EmbeddedDriver"));
} catch (NoClassDefFoundError ne) {
LOGGER.debug("At [3b] -- " + ne);
ne.printStackTrace();
} catch (Exception e) {
LOGGER.debug("At [3] -- " + e);
e.printStackTrace();
}

/// ERROR FOR STACKOVERFLOW IS GENERATED FROM THIS LINE!!!!
LOGGER.debug("At HomePage - jdbcHandler [3]: " + jdbcWicketSpringHandler.toStringJdbcTemplate());
LOGGER.debug("At HomePage - jdbcHandler [3]: " + jdbcWicketSpringHandler.data());

...

} // End of Class //

编辑:
我可能缺少一个依赖 Spring Jdbc 或 dbcp 的 jar 文件。

这是我的 WEB-INF/lib 列表:
antlr-2.7.6.jar
aopalliance-1.0.jar
avalon-framework-4.1.3.jar
axis-1.4.jar
axis-jaxrpc-1.4.jar
cglib-nodep-2.2.jar
commons-collections-3.1.jar
commons-dbcp-1.2.2.jar
commons-logging-1.1.jar
commons-pool-1.3.jar
derby-10.6.1.0.jar
dom4j-1.6.1.jar
hibernate-core-3.5.1-Final.jar
jetty-6.1.4.jar
jetty-management-6.1.4.jar
jetty-util-6.1.4.jar
jta-1.1.jar
log4j-1.2.14.jar
logkit-1.0.1.jar
mx4j-3.0.1.jar
mx4j-tools-3.0.1.jar
servlet-api-2.5-6.1.4.jar
servlet-api-2.5.jar
slf4j-api-1.5.8.jar
slf4j-log4j12-1.4.2.jar
spring-2.5.6.jar
spring-aop-2.5.6.jar
spring-beans-2.5.6.jar
spring-context-2.5.6.jar
spring-core-2.5.6.jar
spring-jdbc-2.5.6.jar
spring-test-2.5.6.jar
spring-tx-2.5.6.jar
testRunWrapper-1.0.0.jar
wicket-1.4.13.jar
wicket-ioc-1.4.13.jar
wicket-spring-1.4.13.jar
xml-apis-1.0.b2.jar

最佳答案

留言Could not initialize class org.apache.derby.jdbc.EmbeddedDriver意味着此时 JVM 已经尝试初始化这个类但失败了。

如果抛出异常并且未在类的静态初始化器中捕获,则 JVM 将无法初始化类。 JVM 多次尝试初始化 EmbeddedDriver 类的唯一原因是:

  • 一些初始化类的异常被抛出,这个异常在别处被捕获并且程序继续,
  • 引发了一些初始化类的异常,但程序随后输入了 finally块,并在此 finally 内阻止 JVM 尝试再次加载该类。

  • EmbeddedDriver ( source ) 的静态初始值设定项调用 boot()方法。然而,这个 boot()方法调用了相当多的其他代码,因此很难判断问题出在哪里。我看了一些 sourceorg.apache.commons.dbcp.BasicDataSource ,但似乎您的堆栈跟踪中的行号与来源不一致。不知道你用的是哪个版本的commons-dbcp。

    如果您没有其他输出消息或堆栈跟踪,那么最好的办法可能是将 Derby 的源代码附加到您的调试器并逐步查看发生了什么。

    顺便说一句,很可能“打印”一个尚未初始化的类。考虑以下类:
    class St1 {
    static {
    System.out.println("In static initializer");
    }
    }

    public class St2 {
    public static void main(String[] args) {
    System.out.println(St1.class);
    System.out.println(new St1());
    }
    }

    当我运行类(class)时 St2 ,我得到以下输出:

    St1级
    在静态初始化程序中
    St1@65690726

    关于java - Web 环境 Spring/Wicket/Derby/Jetty 中 NoClassDefFoundError 错误的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5597947/

    24 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com