Я использую интеграцию spring 5 и hibernate5. Запустив мое приложение, я получаю эту ошибку:
org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'customerController': Unsatisfied dependency expressed through field 'customerDAO'; nested exception is org.springframework.beans.factory.CannotLoadBeanClassException: Cannot find class [org.springframework.orm.hibernate5.LocalSessionFactoryBean] for bean with name 'sessionFactory' defined in ServletContext resource [/WEB-INF/spring.xml]; nested exception is java.lang.ClassNotFoundException: org.springframework.orm.hibernate5.LocalSessionFactoryBean
org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:598)
org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:90)
Мой файл pom.xml:
<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>Spring_Hibernate</groupId>
<artifactId>Spring_Hibernate</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<spring.version>5.1.0.RELEASE</spring.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>5.1.0.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.1.5.RELEASE</version>
</dependency>
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.2</version>
</dependency>
<!-- https://mvnrepository.com/artifact/javax.servlet/servlet-api -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>taglibs</groupId>
<artifactId>standard</artifactId>
<version>1.1.2</version>
</dependency>
<!-- https://mvnrepository.com/artifact/commons-dbcp/commons-dbcp -->
<dependency>
<groupId>commons-dbcp</groupId>
<artifactId>commons-dbcp</artifactId>
<version>1.4</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-core -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>5.4.1.Final</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-entitymanager -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-entitymanager</artifactId>
<version>5.4.1.Final</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework/spring-orm -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-orm</artifactId>
<version>5.1.4.RELEASE</version>
</dependency>
<dependency>
<groupId>org.hibernate.validator</groupId>
<artifactId>hibernate-validator</artifactId>
<version>6.0.2.Final</version>
</dependency>
<dependency>
<groupId>org.hibernate.validator</groupId>
<artifactId>hibernate-validator-annotation-processor</artifactId>
<version>6.0.2.Final</version>
</dependency>
<dependency>
<groupId>javax.validation</groupId>
<artifactId>validation-api</artifactId>
<version>2.0.1.Final</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator-cdi</artifactId>
<version>6.0.15.Final</version>
</dependency>
<dependency>
<groupId>javax.el</groupId>
<artifactId>el-api</artifactId>
<version>2.2.1-b04</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.jboss.logging/jboss-logging -->
<dependency>
<groupId>org.jboss.logging</groupId>
<artifactId>jboss-logging</artifactId>
<version>3.3.2.Final</version>
</dependency>
<!-- https://mvnrepository.com/artifact/com.fasterxml/classmate -->
<dependency>
<groupId>com.fasterxml</groupId>
<artifactId>classmate</artifactId>
<version>1.3.1</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>6.0.6</version>
</dependency>
</dependencies>
</project>
Мой файл Spring.xml:
**<?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:mvc = "http://www.springframework.org/schema/mvc" xmlns:beans = "http://www.springframework.org/schema/util"
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/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util.xsd">
<!-- Step 3: Add support for component scanning -->
<context:component-scan base-package = "com_spring_hibernate.controller, com_spring_hibernate.dao, com_spring_hibernate.entity" />
<!-- Step 4: Add support for conversion, formatting and validation support -->
<mvc:annotation-driven/>
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/view/" />
<property name = "suffix" value = ".jsp" />
</bean>
<context:property-placeholder location = "classpath:properties/database.properties"/>
<bean id = "sessionFactory" class = "org.springframework.orm.hibernate4.LocalSessionFactoryBean"></bean>
<!--define datasource, define factory which includes data source-->
<bean id = "dataSource" class = "org.apache.commons.dbcp.BasicDataSource" destroy-method = "close">
<property name = "driverClassName" value = "${jdbc.driverClassName}"/>
<property name = "url" value = "${jdbc.url}"/>
<property name = "username" value = "${jdbc.username}"/>
<property name = "password" value = "${jdbc.password}"/>
</bean>
</beans>
Также мой проект включает в себя: классы контроллера, dao/daoImp, entity и util.
Я проверил некоторые знакомые сообщения, которые рекомендуют добавить зависимость от spring-orm (что я уже сделал, но это мне не помогает).
Обновил это до hibernate5, все еще есть та же ошибка
Проверьте, нет ли у вас конфликтующих библиотек Hibernate (несколько версий)
Я добавил maven-enforcer-plugin в свой pom.xml, но после запуска моего приложения я не получаю никаких сообщений о неправильной совместимости.
Попробуйте удалить все зависимости Hibernate из вашего pom.xml и добавить только Вот этот
На самом деле, я обнаружил, что ошибался насчет maven-enforcer-plugin. Он показывает множество ошибок, вот некоторые из них: [ОШИБКА] Ошибка сходимости зависимостей для org.jboss.logging:jboss-logging:3.3.2. Конечные пути к зависимости: +-Spring_Hibernate:Spring_Hibernate:1.0-SNAPSHOT +- org.hibernate:hibernate-core:5.4.1.Final +-org.jboss.logging:jboss-logging:3.3.2.Final и +-Spring_Hibernate:Spring_Hibernate:1.0-SNAPSHOT +-org.hibernate:hibernate-core: 5.4.1.Final +-org.hibernate.common:hibernate-commons-annotations:5.1.0.Final Но как их решить?
Запустите следующую команду в своем проекте из командной строки: mvn dependency:tree -Dverbose и добавьте вывод к своему вопросу. Также попробуйте мое предложение удалить все библиотеки Hibernate и добавить ту, которую я отправил
Я удалил свои зависимости спящего режима, добавил ваши. Выполнить из подсказки: mvn dependency:tree -Dverbose Результат: УСПЕШНАЯ СТРОИТЕЛЬСТВО. Но «Running maven Build» сам по себе по-прежнему показывает те же ошибки; Вывод перед [INFO] BUILD SUCCESS слишком длинный, чтобы разместить его здесь в виде сообщения.
Извините, я забыл указать, вы должны запустить эту команду в папке вашего проекта :)
Я запустил его внутри intellij IDEA «Execute Maven Goal» с рабочим каталогом, который следует за текущим проектом и командной строкой, которую вы отправили ранее. Это правильно?
Вы должны получить результат, подобный примеру в документация.
Да, у меня такой вывод. Он заканчивается: [INFO] BUILD SUCCESS Я только что попытался снова запустить свой проект, и он не показывает никаких ошибок, хотя, если я пытаюсь «Запустить maven Build», он показывает «[INFO] BUILD FAILURE». Как это вообще возможно?
Возможный дубликат Не удается найти класс [org.springframework.orm.hibernate5.LocalSessionFactoryBean] для bean-компонента с именем «hibernate5AnnotatedSessionFactory»




Кажется, у вас есть несколько версий Hibernate в вашем проекте, в файле
spring.xmlвы ссылаетесь на Hibernate 4 ->org.springframework.orm.hibernate4.LocalSessionFactoryBean