2017-02-18 11 views
0

Я ищу рабочую версию конфигурации для весеннего загрузочного приложения для hibernate 4 и mysql.Я застрял с различными комбинациями spring.config, persistence.xml и pom-файлов

Я получаю следующее сообщение об ошибке с моей конфигурацией, так как вчера :(:

org.springframework.beans.factory.BeanCreationException: Ошибка создание компонента с именем «EntityManagerFactory», определенные в классе пути ресурсы [ весна-config.xml]: Призвание метода инициализации не удалось, вложенная исключение java.lang.IllegalStateException: JPA PersistenceProvider возвращается нулевое EntityManagerFactory - проверьте настройки провайдера JPA

!

Это мой persistence.xml файл

<?xml version="1.0" encoding="UTF-8" ?> 


<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="my-pu" transaction-type="RESOURCE_LOCAL"> 
    <provider>org.hibernate.jpa.PersistenceProvider</provider> 

    <class>com.crossover.trial.travelmanagementportal.model.Order</class> 
    <class>com.crossover.trial.travelmanagementportal.model.User</class> 
    <properties> 

    <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver" /> 
    <property name="hibernate.connection.username" value="root"/> 
    <property name="hibernate.connection.password" value="12345678"/> 
    <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/travelmanagement" /> 
    <property name="hibernate.default_schema" value="travelmanagement" /> 
    <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect" /> 
    <property name="hibernate.hbm2ddl.auto" value="create-drop" /> 
    <property name="hibernate.show_sql" value="true"/> 

    </properties> 
    </persistence-unit> 
</persistence> 

И это мой spring.config файл

<?xml version="1.0" encoding="UTF-8"?> 

<beans xmlns="http://www.springframework.org/schema/beans" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" 
    xmlns:tx="http://www.springframework.org/schema/tx" 
    xsi:schemaLocation="http://www.springframework.org/schema/beans 
http://www.springframework.org/schema/beans/spring-beans.xsd 
http://www.springframework.org/schema/context 
http://www.springframework.org/schema/context/spring-context.xsd 
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd 
http://www.springframework.org/schema/tx"> 


    <context:annotation-config /> 

    <context:property-placeholder location="classpath:application.properties" /> 

    <context:component-scan base-package="com.crossover.trial.travelmanagementportal" /> 


    <!-- For @Transactional annotations --> 

    <!-- This makes Spring perform @PersistenceContext/@PersitenceUnit injection: --> 
    <bean 
     class="org.springframework.orm.jpa.support.PersistenceAnnotationBeanPostProcessor" /> 

    <!-- Drives transactions using local JPA APIs --> 

    <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"> 
     <property name="entityManagerFactory" ref="entityManagerFactory" /> 
    </bean> 

    <bean id="jpaAdapter" class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> 
     <property name="showSql" value="true"/> 
     <property name="generateDdl" value="true"/> 
     <property name="database" value="MYSQL"/> 
    </bean> 

    <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"> 
     <property name="persistenceUnitName" value="my-pu" /> 
     <property name="dataSource" ref="dataSource" /> 
     <property name="jpaVendorAdapter" ref="jpaAdapter"/> 
    </bean> 


    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource" > 
     <property name="driverClassName" value="com.mysql.jdbc.Driver" /> 
     <property name="url" value="jdbc:mysql://localhost:3306/travelmanagement" /> 
     <property name="username" value="root" /> 
     <property name="password" value="xxxx" /> 
    </bean> 

    <bean id="currentUserDetailsService" class="com.crossover.trial.travelmanagementportal.service.CurrentUserDetailsService" /> 


    <bean id="encoder" class="org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder"/> 


    <bean id="authProvider" class="org.springframework.security.authentication.dao.DaoAuthenticationProvider"> 
     <property name="userDetailsService" ref="currentUserDetailsService" /> 
     <property name="passwordEncoder" ref="encoder" /> 
    </bean> 

</beans> 

ответ

1

Если вы используете

<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-data-jpa</artifactId> 
</dependency> 

в вашем pom.xml, то вы можете просто настроить подключение к вам db с:

spring.datasource.url= 
spring.datasource.username= 
spring.datasource.password= 
spring.jpa.hibernate.ddl-auto= 

in application.properties

Для создания стартового проекта с пружинным ботинком имеется easy way.

+0

где я должен написать spring.datasource .... в application.properties? –

+0

Где угодно в файле. Файл должен находиться в пути к классам: http://stackoverflow.com/questions/38775194/where-is-the-application-properties-in-spring-boot – MicD

Смежные вопросы