ClassNotFoundException:derby ClientDriver(Spring MVC + Hibernate JPA)

时间:2013-11-05 09:45:04

标签: java spring hibernate derby classnotfoundexception

我正在学习Spring MVC,并尝试使用hibernate连接到数据库。 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

如果有人有任何想法,为什么找不到课程,我很高兴知道! 我试图搜索谷歌和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";
}

@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"; }

1 个答案:

答案 0 :(得分:3)

您需要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提供了工厂Bean。会话工厂又使用数据源来获取它的连接。通过这种方式连接bean,Connection管理变得透明,您可以从应用程序中删除该代码。

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

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