Я использую Spring MVC и пытаюсь подключиться к базе данных MySQL, используя Spring Data JPA с Hibernate в качестве поставщика JPA. Я получил эту ошибку в файле конфигурации JPA:
Из Apache Log:
Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.springframework.orm.jpa.JpaVendorAdapter]: Factory method 'jpaVendorAdapter' threw exception; nested exception is java.lang.ClassFormatError: Duplicate method name&signature in class file org/springframework/orm/jpa/vendor/SpringHibernateJpaPersistenceProvider
at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185)
at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:582)
... 92 more
Caused by: java.lang.ClassFormatError: Duplicate method name&signature in class file org/springframework/orm/jpa/vendor/SpringHibernateJpaPersistenceProvider
at java.base/java.lang.ClassLoader.defineClass1(Native Method)
at java.base/java.lang.ClassLoader.defineClass(ClassLoader.java:1007)
at java.base/java.security.SecureClassLoader.defineClass(SecureClassLoader.java:174)
at org.apache.catalina.loader.WebappClassLoaderBase.findClassInternal(WebappClassLoaderBase.java:2352)
at org.apache.catalina.loader.WebappClassLoaderBase.findClass(WebappClassLoaderBase.java:833)
at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1278)
at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1138)
at org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter.<init>(HibernateJpaVendorAdapter.java:80)
at collaboration.config.SpringDataJpaConfig.jpaVendorAdapter(SpringDataJpaConfig.java:56)
at collaboration.config.SpringDataJpaConfig$$EnhancerBySpringCGLIB$$39a885b5.CGLIB$jpaVendorAdapter$4(<generated>)
at
Вот класс конфигурации SpringDataJPA:
@Configuration
@EnableJpaRepositories("collaboration.data.db")
@EnableTransactionManagement
public class SpringDataJpaConfig {
@Bean
public DataSource dataSource() {
DriverManagerDataSource dataSource
= new DriverManagerDataSource();
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://localhost:3306/collaboration");
dataSource.setUsername("collaboration");
dataSource.setPassword("password");
return dataSource;
}
@Bean
@Autowired
public PlatformTransactionManager transactionManager(EntityManagerFactory emf){
JpaTransactionManager transactionManager = new JpaTransactionManager();
transactionManager.setEntityManagerFactory(emf);
return transactionManager;
}
@Bean
public JpaVendorAdapter jpaVendorAdapter() {
HibernateJpaVendorAdapter adapter = new HibernateJpaVendorAdapter();
adapter.setDatabase(Database.MYSQL);
adapter.setShowSql(false);
adapter.setGenerateDdl(true);
return adapter;
}
@Bean
public LocalContainerEntityManagerFactoryBean entityManagerFactory() {
LocalContainerEntityManagerFactoryBean emf = new LocalContainerEntityManagerFactoryBean();
emf.setDataSource(dataSource());
emf.setPersistenceUnitName("collaboration");
emf.setJpaVendorAdapter(jpaVendorAdapter());
emf.setJpaProperties(jpaProperties);
return emf;
}
@Bean
public PersistenceExceptionTranslationPostProcessor exceptionTranslation(){
return new PersistenceExceptionTranslationPostProcessor();
}
}
РЕДАКТИРОВАТЬ: Вот мой файл build.gradle:
group 'com.example'
version '1.0-SNAPSHOT'
apply plugin: 'war'
apply plugin: 'java'
sourceCompatibility = 1.8
repositories {
mavenCentral()
}
dependencies {
compile "org.springframework:spring-webmvc:$springVersion"
compile "org.springframework.security:spring-security-config:$springSecurityVersion"
compile "org.springframework.security:spring-security-web:$springSecurityVersion"
compile "org.springframework:spring-context:$springVersion"
compile "org.springframework:spring-orm:$springVersion"
compile "org.springframework.data:spring-data-jpa:$springDataJpaVersion"
compile "org.hibernate:hibernate-core:$hibernateCore"
compile "javax.inject:javax.inject:1"
//data validation
compile "org.hibernate:hibernate-validator:5.4.1.Final"
compile group: 'javax.validation', name: 'validation-api', version: '2.0.1.Final'
// https://mvnrepository.com/artifact/commons-beanutils/commons-beanutils
compile group: 'commons-beanutils', name: 'commons-beanutils', version: '1.9.3'
// https://mvnrepository.com/artifact/mysql/mysql-connector-java
compile group: 'mysql', name: 'mysql-connector-java', version: '8.0.12'
// thymleaf dependencies
compile "org.thymeleaf:thymeleaf-spring5:$thymleafSpring5Version"
compile group: 'org.thymeleaf.extras', name: 'thymeleaf-extras-springsecurity4', version: '3.0.2.RELEASE'
//bootstrap
compile "org.webjars:bootstrap:$bootstrapVersion"
providedCompile "javax.el:javax.el-api:$jspElVersion"
providedCompile "javax.servlet:javax.servlet-api:$javaxServletApi"
testCompile group: 'junit', name: 'junit', version: '4.12'
testCompile "junit:junit-dep:$junitVersion"
testCompile "org.springframework:spring-test:$springVersion"
testCompile "org.mockito:mockito-core:$mockitoVersion"
testCompile group: 'org.slf4j', name: 'slf4j-simple', version: '1.7.25'
//selenium driver
compile group: 'org.seleniumhq.selenium', name: 'selenium-java', version: '3.12.0'
compile group: 'org.seleniumhq.selenium', name: 'selenium-chrome-driver', version: '3.12.0'
}
task wrapper(type: Wrapper) {
gradleVersion = '4.1'
}
war {
baseName = 'collaboration'
}
Есть идеи, чем это может быть вызвано?