Схожу с ума.Spring 3.0.x Hibernate 3.6.5 JPA - Невозможно настроить EntityManagerFactory - PullRequest
2 голосов
/ 19 июня 2011

Я схожу с ума последние несколько часов. Я просто не могу настроить Spring, Hibernate, с JPA.

У меня есть проект GWT по умолчанию. Единственное, что не используется по умолчанию - я решил использовать JSON для связи с сервером в обоих направлениях. Я использую Jax-RS (Джерси), чтобы сделать это.

Мой каталог war выглядит следующим образом, ДО того, как я пытаюсь добавить в проект spring или hibernate:

  • Война
  • война / имя-проекта
  • война / WEB-INF
  • war / WEB-INF / классы (и подкаталоги)
  • война / Lib
  • война / Lib / ASM-3.1.jar
  • война / Lib / flexjson-2.1.jar
  • война / Lib / GWT-servlet.jar
  • война / Библиотека / ДЖЕКСОНА-ядро-ASL-1.7.1.jar
  • война / Библиотека / ДЖЕКСОНА-jaxrs-1.7.1.jar
  • война / Библиотека / ДЖЕКСОН-картограф-ASL-1.7.1.jar
  • война / Библиотека / ДЖЕКСОН-хс-1.7.1.jar
  • война / Lib / джерси-клиент-1.7.jar
  • война / Lib / Джерси-ядро-1.7.jar
  • война / Lib / джерси-JSON-1.7.jar
  • война / Lib / джерси-сервер 1.7.jar
  • война / Lib / отстрелить-1.1.jar
  • война / Библиотека / jsr311-апи-1.1.1.jar
  • война / web.xml

Не так уж и плохо, 13 JARS и один XML-файл, содержащий несколько строк. Это довольно компактно, у меня есть JSON, идущий вперед и назад, как ожидалось. Отлично. Теперь все, что мне нужно сделать, это добавить ORM. Я использовал Spring и hibernate в прошлых проектах, но никогда не настраивал их.

Проблема в том, как узнать, как их настроить? Если вы воспользуетесь Google, вы найдете миллионы учебников (большинство из них устарели). Учебное пособие по гибернации великолепно, и я почти на 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
  • война / Библиотека / Обще-каротаж 1.1.1.jar
  • война / Библиотека / dom4j-1.6.1.jar
  • война / Lib / flexjson-2.1.jar
  • война / Lib / GWT-servlet.jar
  • война / Библиотека / гибернации-JPA-2,0-апи-1.0.0.Final.jar
  • война / Lib / hibernate3.jar
  • война / Библиотека / ДЖЕКСОНА-ядро-ASL-1.7.1.jar
  • война / Библиотека / ДЖЕКСОНА-jaxrs-1.7.1.jar
  • война / Библиотека / ДЖЕКСОН-картограф-ASL-1.7.1.jar
  • война / Lib / Javassist-3.12.0.GA.jar
  • война / Библиотека / ДЖЕКСОН-хс-1.7.1.jar
  • война / Lib / джерси-клиент-1.7.jar
  • война / Lib / Джерси-ядро-1.7.jar
  • война / Lib / джерси-JSON-1.7.jar
  • война / Lib / джерси-сервер 1.7.jar
  • война / Lib / отстрелить-1.1.jar
  • война / Библиотека / jsr311-апи-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
  • война / Библиотека / org.springframework.context-3.0.5.RELEASE.jar
  • война / Библиотека / 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
  • war / lib / org.springframework.jdbc-3.0.5.RELEASE.jar
  • war / lib / org.springframework.jms-3.0.5.RELEASE.jar
  • war/lib/org.springframework.orm-3.0.5.RELEASE.jar
  • war / lib / org.springframework.oxm-3.0.5.RELEASE.jar
  • war / lib / org.springframework.test-3.0.5.RELEASE.jar
  • war / lib / org.springframework.transaction-3.0.5.RELEASE.jar
  • war / lib / org.springframework.web-3.0.5.RELEASE.jar
  • war / lib / org.springframework.web.portlet-3.0.5.RELEASE.jar
  • war / lib / org.springframework.web.servlet-3.0.5.RELEASE.jar
  • war / lib / org.springframework.web.struts-3.0.5.RELEASE.jar
  • war / lib / slf4j-api-1.6.1.jar
  • war / lib / slf4j-log4j12-1.6.1.jar
  • war / applicationContext.xml
  • war / 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. Может ли кто-нибудь отослать меня кy простое (и обновленное на сегодняшний день!) руководство по настройке этих фреймворков?Дело не в том, что я не понимаю спящий режим.Я использовал его в течение последних 3 лет (хотя очень интенсивно в последние несколько месяцев в виде Грааля).

Спасибо

Ответы [ 4 ]

3 голосов
/ 19 июня 2011

Похоже, приложение ищет провайдера проверки .Добавьте hibernate-validator 4.x в ваш путь к классам.

1 голос
/ 08 августа 2012

Я получаю то же сообщение об ошибке:

org.springframework.beans.factory.BeanCreationException: Ошибка создания бина с именем «myName» ...: сбой вызова метода init;вложенным исключением является javax.persistence.PersistenceException: [PersistenceUnit: MyPersistenceUnit] Невозможно настроить EntityManagerFactory "

Оказалось, что один из вновь добавленных классов Entity не имеет первичного ключа @Id, определенного. Hopeэто поможет кому-то в будущем.

1 голос
/ 21 декабря 2011

Какую версию GWt вы используете? GWT2.3 и более поздние версии имеют реализацию валидатора. Вы должны добавить их точно в classpath.

0 голосов
/ 08 мая 2012

"Если вы не хотите использовать проверку bean-компонента hibernate, вы можете добавить эту строку в файл persistence.xml hibernate:

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

Это решит проблему без добавления путей к классам.

источник: http://comments.gmane.org/gmane.org.google.gwt/60720

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...