快要疯了。 Spring 3.0.x Hibernate 3.6.5 JPA - 无法配置EntityManagerFactory

时间:2011-06-19 01:49:06

标签: hibernate spring gwt jpa

过去几个小时我一直在发疯。我根本无法使用JPA配置Spring,Hibernate。

我有一个默认的GWT项目。唯一非默认的事情是我决定使用JSON与服务器进行双向通信。我正在使用jax-rs(jersey)来做到这一点。

我的war目录在尝试将spring或hibernate添加到项目之前看起来像这样:

  • 战/项目名称
  • 战/ WEB-INF
  • war / WEB-INF / classes(和子目录)
  • 战/ lib中
  • 战/ LIB / ASM-3.1.jar
  • 战/ LIB / flexjson-2.1.jar
  • 战/ LIB / GWT-的servlet.jar
  • 战/ LIB /杰克逊核-ASL-1.7.1.jar
  • 战/ LIB /杰克逊 - JAXRS-1.7.1.jar
  • 战/ LIB /杰克逊映射器-ASL-1.7.1.jar
  • 战/ LIB /杰克逊-XC-1.7.1.jar
  • 战/ LIB / Jersey的客户端 - 1.7.jar
  • 战/ LIB /球衣核-1.7.jar
  • 战/ LIB / Jersey的JSON-1.7.jar
  • 战/ LIB /球衣 - 服务器 - 1.7.jar
  • 战/ LIB /抛放-1.1.jar
  • 战/ LIB / JSR311-API-1.1.1.jar
  • 战/ web.xml中

还不错,13个JARS和一个包含几行的XML文件。它非常紧凑,我让JSON按预期来回传递。完善。现在我所要做的就是添加ORM。我在过去的项目中使用过Spring和hibernate,但我从来没有真正配置它们。

问题是,您如何找到如何配置它们?如果你谷歌它,你会发现数以百万计的教程(其中大部分是过时的)。 hibernate教程很棒,我几乎100%肯定我可以轻松地进行简单的休眠(事实上我很久以前做过)。但我想坚持使用行业惯例,并将Hibernate与Spring和JPA一起使用。

我在这里找到了这个教程,它似乎是最新的: http://www.javacodegeeks.com/2010/05/gwt-2-spring-3-jpa-2-hibernate-35.html

但我要进入圈子。问题后的问题。在我启动GWT应用程序后,我得到了这个:

log4j:WARN No appenders could be found for logger (org.springframework.web.context.ContextLoader).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
[WARN] Server class 'javax.validation.Validation' could not be found in the web app, but was found on the system classpath
   [WARN] Adding classpath entry 'file:/Users/jose/springsource/sts-2.5.2.SR1/plugins/com.google.gwt.eclipse.sdkbundle_2.3.0.r36v201105191508/gwt-2.3.0/validation-api-1.0.0.GA.jar' to the web app classpath for this session
   For additional info see: file:/Users/jose/springsource/sts-2.5.2.SR1/plugins/com.google.gwt.eclipse.sdkbundle_2.3.0.r36v201105191508/gwt-2.3.0/doc/helpInfo/webAppClassPath.html
Starting Jetty on port 8888
   [WARN] Failed startup of context com.google.gwt.dev.shell.jetty.JettyLauncher$WebAppContextWithReload@48270dbf{/,/Users/jose/workspace/MyProject/war}
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'entityManagerFactory' defined in ServletContext resource [/WEB-INF/applicationContext.xml]: Invocation of init method failed; nested exception is javax.persistence.PersistenceException: [PersistenceUnit: MyPersistenceUnit] Unable to configure EntityManagerFactory
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1420)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)
    at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:291)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:288)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:190)
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:563)
    at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:895)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:425)
    at org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:276)
    at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:197)
    at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:47)
    at org.mortbay.jetty.handler.ContextHandler.startContext(ContextHandler.java:543)
    at org.mortbay.jetty.servlet.Context.startContext(Context.java:136)
    at org.mortbay.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1220)
    at org.mortbay.jetty.handler.ContextHandler.doStart(ContextHandler.java:513)
    at org.mortbay.jetty.webapp.WebAppContext.doStart(WebAppContext.java:448)
    at com.google.gwt.dev.shell.jetty.JettyLauncher$WebAppContextWithReload.doStart(JettyLauncher.java:463)
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:39)
    at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130)
    at org.mortbay.jetty.handler.RequestLogHandler.doStart(RequestLogHandler.java:115)
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:39)
    at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130)
    at org.mortbay.jetty.Server.doStart(Server.java:222)
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:39)
    at com.google.gwt.dev.shell.jetty.JettyLauncher.start(JettyLauncher.java:667)
    at com.google.gwt.dev.DevMode.doStartUpServer(DevMode.java:500)
    at com.google.gwt.dev.DevModeBase.startUp(DevModeBase.java:1055)
    at com.google.gwt.dev.DevModeBase.run(DevModeBase.java:804)
    at com.google.gwt.dev.DevMode.main(DevMode.java:309)
Caused by: javax.persistence.PersistenceException: [PersistenceUnit: MyPersistenceUnit] Unable to configure EntityManagerFactory
    at org.hibernate.ejb.Ejb3Configuration.configure(Ejb3Configuration.java:378)
    at org.hibernate.ejb.HibernatePersistence.createEntityManagerFactory(HibernatePersistence.java:56)
    at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:48)
    at org.springframework.orm.jpa.LocalEntityManagerFactoryBean.createNativeEntityManagerFactory(LocalEntityManagerFactoryBean.java:92)
    at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.afterPropertiesSet(AbstractEntityManagerFactoryBean.java:308)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1477)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1417)
    ... 30 more
Caused by: org.hibernate.HibernateException: Unable to get the default Bean Validation factory
    at org.hibernate.cfg.beanvalidation.BeanValidationActivator.applyDDL(BeanValidationActivator.java:127)
    at org.hibernate.cfg.Configuration.applyBeanValidationConstraintsOnDDL(Configuration.java:1704)
    at org.hibernate.cfg.Configuration.applyConstraintsToDDL(Configuration.java:1654)
    at org.hibernate.cfg.Configuration.secondPassCompile(Configuration.java:1445)
    at org.hibernate.cfg.Configuration.buildMappings(Configuration.java:1375)
    at org.hibernate.ejb.Ejb3Configuration.buildMappings(Ejb3Configuration.java:1519)
    at org.hibernate.ejb.EventListenerConfigurator.configure(EventListenerConfigurator.java:193)
    at org.hibernate.ejb.Ejb3Configuration.configure(Ejb3Configuration.java:1100)
    at org.hibernate.ejb.Ejb3Configuration.configure(Ejb3Configuration.java:282)
    at org.hibernate.ejb.Ejb3Configuration.configure(Ejb3Configuration.java:366)
    ... 36 more
Caused by: java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.hibernate.cfg.beanvalidation.BeanValidationActivator.applyDDL(BeanValidationActivator.java:118)
    ... 45 more
Caused by: org.hibernate.HibernateException: Unable to build the default ValidatorFactory
    at org.hibernate.cfg.beanvalidation.TypeSafeActivator.getValidatorFactory(TypeSafeActivator.java:383)
    at org.hibernate.cfg.beanvalidation.TypeSafeActivator.applyDDL(TypeSafeActivator.java:109)
    ... 50 more
Caused by: javax.validation.ValidationException: Unable to find a default provider
    at javax.validation.Validation$GenericBootstrapImpl.configure(Validation.java:264)
    at javax.validation.Validation.buildDefaultValidatorFactory(Validation.java:111)
    at org.hibernate.cfg.beanvalidation.TypeSafeActivator.getValidatorFactory(TypeSafeActivator.java:380)
    ... 51 more
   [WARN] Nested in org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'entityManagerFactory' defined in ServletContext resource [/WEB-INF/applicationContext.xml]: Invocation of init method failed; nested exception is javax.persistence.PersistenceException: [PersistenceUnit: MyPersistenceUnit] Unable to configure EntityManagerFactory:
javax.validation.ValidationException: Unable to find a default provider
    at javax.validation.Validation$GenericBootstrapImpl.configure(Validation.java:264)
    at javax.validation.Validation.buildDefaultValidatorFactory(Validation.java:111)
    at org.hibernate.cfg.beanvalidation.TypeSafeActivator.getValidatorFactory(TypeSafeActivator.java:380)
    at org.hibernate.cfg.beanvalidation.TypeSafeActivator.applyDDL(TypeSafeActivator.java:109)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.hibernate.cfg.beanvalidation.BeanValidationActivator.applyDDL(BeanValidationActivator.java:118)
    at org.hibernate.cfg.Configuration.applyBeanValidationConstraintsOnDDL(Configuration.java:1704)
    at org.hibernate.cfg.Configuration.applyConstraintsToDDL(Configuration.java:1654)
    at org.hibernate.cfg.Configuration.secondPassCompile(Configuration.java:1445)
    at org.hibernate.cfg.Configuration.buildMappings(Configuration.java:1375)
    at org.hibernate.ejb.Ejb3Configuration.buildMappings(Ejb3Configuration.java:1519)
    at org.hibernate.ejb.EventListenerConfigurator.configure(EventListenerConfigurator.java:193)
    at org.hibernate.ejb.Ejb3Configuration.configure(Ejb3Configuration.java:1100)
    at org.hibernate.ejb.Ejb3Configuration.configure(Ejb3Configuration.java:282)
    at org.hibernate.ejb.Ejb3Configuration.configure(Ejb3Configuration.java:366)
    at org.hibernate.ejb.HibernatePersistence.createEntityManagerFactory(HibernatePersistence.java:56)
    at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:48)
    at org.springframework.orm.jpa.LocalEntityManagerFactoryBean.createNativeEntityManagerFactory(LocalEntityManagerFactoryBean.java:92)
    at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.afterPropertiesSet(AbstractEntityManagerFactoryBean.java:308)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1477)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1417)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)
    at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:291)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:288)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:190)
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:563)
    at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:895)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:425)
    at org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:276)
    at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:197)
    at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:47)
    at org.mortbay.jetty.handler.ContextHandler.startContext(ContextHandler.java:543)
    at org.mortbay.jetty.servlet.Context.startContext(Context.java:136)
    at org.mortbay.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1220)
    at org.mortbay.jetty.handler.ContextHandler.doStart(ContextHandler.java:513)
    at org.mortbay.jetty.webapp.WebAppContext.doStart(WebAppContext.java:448)
    at com.google.gwt.dev.shell.jetty.JettyLauncher$WebAppContextWithReload.doStart(JettyLauncher.java:463)
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:39)
    at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130)
    at org.mortbay.jetty.handler.RequestLogHandler.doStart(RequestLogHandler.java:115)
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:39)
    at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130)
    at org.mortbay.jetty.Server.doStart(Server.java:222)
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:39)
    at com.google.gwt.dev.shell.jetty.JettyLauncher.start(JettyLauncher.java:667)
    at com.google.gwt.dev.DevMode.doStartUpServer(DevMode.java:500)
    at com.google.gwt.dev.DevModeBase.startUp(DevModeBase.java:1055)
    at com.google.gwt.dev.DevModeBase.run(DevModeBase.java:804)
    at com.google.gwt.dev.DevMode.main(DevMode.java:309)

这是我的战争目前直接看起来的样子:

  • 战/项目名称
  • 战/ WEB-INF
  • war / WEB-INF / classes(和子目录)
  • 战/ META-INF / persistence.xml中
  • 战/ lib中
  • 战/ LIB / ANTLR-2.7.6.jar
  • 战/ LIB / aopalliance.jar
  • 战/ LIB / ASM-3.1.jar
  • 战/ LIB / c3p0-0.9.1.jar
  • 战/ LIB /公地集合-3.1.jar
  • 战/ LIB /共享记录-1.1.1.jar
  • 战/ LIB / DOM4J-1.6.1.jar
  • 战/ LIB / flexjson-2.1.jar
  • 战/ LIB / GWT-的servlet.jar
  • 战/ LIB /休眠-JPA-2.0-API-1.0.0.Final.jar
  • 战/ LIB / hibernate.jar文件
  • 战/ LIB /杰克逊核-ASL-1.7.1.jar
  • 战/ LIB /杰克逊 - JAXRS-1.7.1.jar
  • 战/ LIB /杰克逊映射器-ASL-1.7.1.jar
  • 战/ LIB /了Javassist-3.12.0.GA.jar
  • 战/ LIB /杰克逊-XC-1.7.1.jar
  • 战/ LIB / Jersey的客户端 - 1.7.jar
  • 战/ LIB /球衣核-1.7.jar
  • 战/ LIB / Jersey的JSON-1.7.jar
  • 战/ LIB /球衣 - 服务器 - 1.7.jar
  • 战/ LIB /抛放-1.1.jar
  • 战/ LIB / JSR311-API-1.1.1.jar
  • 战/ LIB / JTA-1.1.jar
  • 战/ LIB / log4j的-1.2.16.jar
  • 战/ lib中/ MySQL的连接器的Java-5.1.16-bin.jar
  • 战/ LIB / org.springframework.aop-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.asm-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.aspects-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.beans-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.context-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.context.support-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.core-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.expression-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.instrument-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.instrument.tomcat-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.jdbc-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.jms-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.orm-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.oxm-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.test-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.transaction-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.web-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.web.portlet-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.web.servlet-3.0.5.RELEASE.jar
  • 战/ LIB / org.springframework.web.struts-3.0.5.RELEASE.jar
  • 战/ LIB / SLF4J-API-1.6.1.jar
  • 战/ LIB / SLF4J-log4j12-1.6.1.jar
  • 战/ applicationContext.xml的
  • 战/ web.xml中

这是我的web.xml          

<web-app>

    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>

    <!-- Servlets -->

    <servlet>
        <servlet-name>Jersey REST Service</servlet-name>
        <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
        <init-param>
            <param-name>com.sun.jersey.config.property.packages</param-name>
            <param-value>com.jose.server</param-value>
        </init-param>
        <init-param>
            <param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name>
            <param-value>true</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>Jersey REST Service</servlet-name>
        <url-pattern>/rest/*</url-pattern>
    </servlet-mapping>

    <!-- Default page to serve -->
    <welcome-file-list>
        <welcome-file>MyProject.html</welcome-file>
    </welcome-file-list>

</web-app>

这是我的persistence.xml:

<persistence xmlns="http://java.sun.com/xml/ns/persistence"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
    version="2.0">

    <persistence-unit name="MyPersistenceUnit" transaction-type="RESOURCE_LOCAL">
        <provider>org.hibernate.ejb.HibernatePersistence</provider>

        <properties>
            <property name="hibernate.hbm2ddl.auto" value="update"/>
            <property name="hibernate.show_sql" value="false"/>
            <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5InnoDBDialect"/>
            <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/>
            <property name="hibernate.connection.url" value="jdbc:mysql://localhost/blah"/>
            <property name="hibernate.connection.username" value="sa"/>
            <property name="hibernate.connection.password" value=""/>

            <property name="hibernate.c3p0.min_size" value="5"/>
            <property name="hibernate.c3p0.max_size" value="20"/>
            <property name="hibernate.c3p0.timeout" value="300"/>
            <property name="hibernate.c3p0.max_statements" value="50"/>
            <property name="hibernate.c3p0.idle_test_period" value="3000"/>
        </properties>

    </persistence-unit>

</persistence>
  1. 有谁知道为什么我遇到上述错误?
  2. 有人可以向我推荐一个关于如何配置这些框架的非常简单的(及时更新!)教程吗?这不是我不理解hibernate。我在过去3年里一直使用它(虽然在过去的几个月中只是以Grails的形式出现了很多)。
  3. 由于

4 个答案:

答案 0 :(得分:3)

应用程序似乎正在寻找validation provider。将hibernate-validator 4.x添加到类路径中。

答案 1 :(得分:1)

您使用的是哪个版本的GWt? GWT2.3及更高版本具有验证器实现。您需要在类路径中进行详细添加。

答案 2 :(得分:1)

我收到了同样的错误消息:

  

org.springframework.beans.factory.BeanCreationException:创建名为'myName'的bean时出错......:   调用init方法失败;嵌套异常是javax.persistence.PersistenceException:   [PersistenceUnit:MyPersistenceUnit]无法配置EntityManagerFactory“

原来,其中一个新添加的Entity类没有定义主键@Id。希望将来帮助某人。

答案 3 :(得分:0)

“如果您不想使用hibernate bean验证,可以添加它 行到你的休眠persistence.xml文件:

  <validation-mode>NONE</validation-mode>"

这样可以在不添加类路径的情况下解决问题。

来源:http://comments.gmane.org/gmane.org.google.gwt/60720