【问题标题】:ClassNotFoundException: derby ClientDriver (Spring MVC + Hibernate JPA)ClassNotFoundException: derby ClientDriver (Spring MVC + Hibernate JPA)
【发布时间】:2013-11-05 09:45:03
【问题描述】:

我正在学习 Spring MVC,并尝试使用休眠连接到数据库。 MVC 部分工作,在一个单独的项目中,我还可以连接并使用 Derby 数据库。但是当我试图将两者放在一起时,我失败了。

根本原因:

java.lang.NoClassDefFoundError: org/apache/derby/jdbc/ClientDriver
hu.pikk.controller.PikkController.test(PikkController.java:42)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
java.lang.reflect.Method.invoke(Method.java:606)
org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:219

我不明白这是为什么,因为我在 maven 文件中放入了 derby 依赖项:

<dependency>
    <groupId>org.apache.derby</groupId>
    <artifactId>derby</artifactId>
    <version>10.10.1.1</version>
</dependency>

我还将 derbyclient.jar 文件放到了我的类路径中:

..Java\jdk1.7.0_45\db\lib\derbyclient.jar

如果有人有任何想法,为什么找不到课程,我很高兴知道! 我尝试在 google 和 stackoverflow 搜索类似的错误,但没有一个答案有用。

我尝试以不同的方式在我的控制器类中创建一个实体管理器:

@RequestMapping(value={"/","/test"},method = RequestMethod.GET)
public String test(ModelMap model) {
    try {
        DriverManager.registerDriver(new org.apache.derby.jdbc.ClientDriver());
    } catch (SQLException e) {
        e.printStackTrace();
    }
    ClientDriver driver = new ClientDriver();

//  factory = Persistence.createEntityManagerFactory("punit"); //Specified JDBC Driver org.apache.derby.jdbc.ClientDriver could not be loaded

//  manager = factory.createEntityManager();
//  HibernatePersistence hp = new HibernatePersistence();
//  factory = hp.createEntityManagerFactory("persistence.xml",null);
    if(factory!=null){
        manager = factory.createEntityManager();
    }else{
        System.out.println( "### FACTORY IS NULL ### ");
    }

    //manager.getTransaction().begin();
    //Employee first = manager.find(Employee.class, 1);
    //manager.getTransaction().commit();
    //model.addAttribute("employee", first);
    if(manager==null){
        model.addAttribute("message", "Persistence manager is NULL");
    }else{
        model.addAttribute("message", "Persistence manager is not NULL! Hurray!");
    }

    return "test";
}

【问题讨论】:

    标签: java spring hibernate derby classnotfoundexception


    【解决方案1】:

    您需要 derby 客户端的依赖项

    <dependency>
        <groupId>org.apache.derby</groupId>
        <artifactId>derbyclient</artifactId>
        <version>10.10.1.1</version>
    </dependency>
    

    您还需要确保它在您的容器中可用。你不妨关注spring tutorial for web MVC that covers data access

    编辑

    我不会混合依赖解析。如果您使用的是 Maven,请坚持使用它。通常将依赖项标记为provided,因为您的容器会将 jar 作为其设置的一部分进行部署。例如,如果您的容器是 Tomcat,您可以将 jar 放在 $TOMCAT_HOME/lib

    您还应该注意 Spring 为 create a Session Factory 提供了 Factory Bean。会话工厂反过来使用数据源来获取它的连接。通过以这种方式连接 bean,连接管理变得透明,您可以从应用程序中删除该代码。

    在典型的 n 层应用程序中,数据访问实现的细节被封装在存储库/DAO 层中,然后从服务层访问该层。服务层捕获业务逻辑并协调数据输入/检索。

    您的控制器应该只关心在传递到服务层之前捕获/验证输入,并以客户端期望的格式(HTML、JSON、XML 等)返回输出

    【讨论】:

    • 看起来添加这个解决了它,但我不知道为什么,因为我之前将 derbyclient.jar 添加到我的构建路径中,但它没有工作。好的,我找到了原因:将jar放在构建路径上是不够的,(在eclipse中),我必须将jar添加到项目属性/部署程序集/Web部署程序集中。
    猜你喜欢
    • 1970-01-01
    • 2011-07-27
    • 2014-09-08
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-08-22
    • 2021-12-13
    • 1970-01-01
    相关资源
    最近更新 更多