SpringBoot BeanCreationException: ошибка при создании bean-компонента с именем requestMappingHandlerAdapter. Причина: java.lang.NoSuchFieldError: defaultInstance

У меня есть проект SpringBoot + Maven с JPA. При попытке запустить приложение я получил следующий стек ошибок.

Ниже мой файл pom.xml.

Есть идеи, как это исправить?

 <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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
 <modelVersion>4.0.0</modelVersion>
 <parent>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-parent</artifactId>
     <version>2.3.4.RELEASE</version>
     <relativePath/> <!-- lookup parent from repository -->
 </parent>
 <groupId>com.demo</groupId>
 <artifactId>docker-example</artifactId>
 <version>0.0.1-SNAPSHOT</version>
 <name>docker-example</name>
 <description>Docker Example</description>

 <properties>
     <java.version>1.8</java.version>
 </properties>

 <dependencies>
     <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter</artifactId>
     </dependency>
     <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
     </dependency>
     <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-test</artifactId>
         <scope>test</scope>
         <exclusions>
             <exclusion>
                 <groupId>org.junit.vintage</groupId>
                 <artifactId>junit-vintage-engine</artifactId>
             </exclusion>
         </exclusions>
     </dependency>
     <dependency>
         <groupId>org.springframework</groupId>
         <artifactId>spring-web</artifactId>
         <version>5.2.8.RELEASE</version>
     </dependency>
     <!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
     <dependency>
         <groupId>org.projectlombok</groupId>
         <artifactId>lombok</artifactId>
         <version>1.18.12</version>
         <scope>provided</scope>
     </dependency>
     <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-data-jpa</artifactId>
     </dependency>
     <dependency>
         <groupId>mysql</groupId>
         <artifactId>mysql-connector-java</artifactId>
         <version>8.0.18</version>
     </dependency>
 </dependencies>

 <build>
     <finalName>app</finalName>
     <plugins>
         <plugin>
             <groupId>org.springframework.boot</groupId>
             <artifactId>spring-boot-maven-plugin</artifactId>
         </plugin>
     </plugins>
 </build>
</project>

Описанная проблема связана с конфликтами между различными зависимостями Maven. У меня была такая же проблема при попытке использовать последнюю версию Spring Boot с Apache Camel.


person pasindupa    schedule 22.09.2020    source источник


Ответы (2)


После анализа дерева зависимостей выяснилось, что версия spring-webmvc была 5.2.9, в то время как все остальные зависимости Spring были версии 5.2.8.

В моем случае я решил проблему, используя более новую версию camel-spring-boot-dependencies (3.6.0, в отличие от ранее использовавшейся 3.5.0).

Нашел решение.

person Aleksandar Radulović    schedule 05.11.2020

В моем pom.xml было две зависимости, например

Я удалил зависимость spring-web, перезагрузил все плагины Maven и снова попытался запустить проект.

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

<dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-web</artifactId>
        <version>5.2.8.RELEASE</version>
</dependency>

Это было успешно.

У меня та же проблема, но у меня нет зависимости spring-web :( И я вижу это после обновления до Spring 5.2.9 :(

person pasindupa    schedule 22.09.2020
comment
org.springframework.beans.factory.BeanCreationException: ошибка при создании bean-компонента с именем 'requestMappingHandlerAdapter', определенным в ресурсе пути к классу [org / springframework / boot / autoconfigure / web / servlet / WebMvcAutoConfiguration $ EnableWebMvcConfiguration.class]: не удалось вызвать метод инициализации; вложенное исключение - java.lang.NoSuchFieldError: defaultInstance в org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean (AbstractAutowireCapableBeanFactory.java:1794.java: 5.2.9.java: beans-beans. ] в org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean (AbstractAutowireCapableBeanFactory.java:594) ~ [spring-beans-5.2.9.RELEASE.jar: 5.2.9.RELEASE.fctory.factor.orrameg. .support.AbstractAutowireCapableBeanFactory.createBean (AbstractAutowireCapableBeanFactory.java:516) ~ [spring-beans-5.2.9.RELEASE.jar: 5.2.9.RELEASE] в org.springframeworket.beans.factory.stractBepportan.A $ do (AbstractBeanFactory.java:324) ~ [spring-beans-5.2.9.RELEASE.jar: 5.2.9.RELEASE] в org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton (DefaultSingletonBeanRegistry.java:234) ~ [ spring-beans-5.2.9.RELEASE.jar: 5.2.9.RELEASE] в org.springframework.beans.factory.supp ort.AbstractBeanFactory.doGetBean (AbstractBeanFactory.java:322) ~ [spring-beans-5.2.9.RELEASE.jar: 5.2.9.RELEASE] на org.springframework.beans.factory.support.AbstractBeanFactory.getavaBeanctory (AbstractBeanFactory.getavaBeanctory ( : 202) ~ [spring-beans-5.2.9.RELEASE.jar: 5.2.9.RELEASE] в org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons (DefaultListableBeanFactory.java:897) ~ [spring-beans- 5.2.9.RELEASE.jar: 5.2.9.RELEASE] в org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization (AbstractApplicationContext.java:879) ~ [spring-context-5.2.9.RELEASE.jar: 5.2.9 .RELEASE] в org.springframework.context.support.AbstractApplicationContext.refresh (AbstractApplicationContext.java:551) ~ [spring-context-5.2.9.RELEASE.jar: 5.2.9.RELEASE] в org.springframework.boot.web .servlet.context.ServletWebServerApplicationContext.refresh (ServletWebServerApplicationContext.java:143) ~ [spring-boot-2.3.4.RELEASE.jar: 2.3.4.RELEASE] в org.springframework.boo t.SpringApplication.refresh (SpringApplication.java:758) [spring-boot-2.3.4.RELEASE.jar: 2.3.4.RELEASE] в org.springframework.boot.SpringApplication.refresh (SpringApplication.java:750) [spring -загрузка-2. 3.4.RELEASE.jar: 2.3.4.RELEASE] в org.springframework.boot.SpringApplication.refreshContext (SpringApplication.java:397) [spring-boot-2.3.4.RELEASE.jar: 2.3.4.RELEASE] в org .springframework.boot.SpringApplication.run (SpringApplication.java:315) [spring-boot-2.3.4.RELEASE.jar: 2.3.4.RELEASE] в org.springframework.boot.SpringApplication.run (SpringApplication.java:1237 ) [spring-boot-2.3.4.RELEASE.jar: 2.3.4.RELEASE] в org.springframework.boot.SpringApplication.run (SpringApplication.java:1226) [spring-boot-2.3.4.RELEASE.jar: 2.3.4.RELEASE] в com.pasindu.dockerexample.DockerExampleApplication.main (DockerExampleApplication.java:14) [classes /: na] Вызвано: java.lang.NoSuchFieldError: defaultInstance в org.springframework.web.servlet.mvc. method.annotation.ServletCookieValueMethodArgumentResolver. (ServletCookieValueMethodArgumentResolver.java:40) ~ [spring-webmvc-5.2.9.RELEASE.jar: 5.2.9.RELEASE] в org.spring.RELEASE. getDefaultArgu mentResolvers (RequestMappingHandlerAdapter.java:648) ~ [spring-webmvc-5.2.9.RELEASE.jar: 5.2.9.RELEASE] в org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.afterAdMapping : 561) ~ [spring-webmvc-5.2.9.RELEASE.jar: 5.2.9.RELEASE] в org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods (AbstractAutowireCapableBeanFactory:18-53.java) [beans. 5.2.9.RELEASE.jar: 5.2.9.RELEASE] в org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean (AbstractAutowireCapableBeanFactory.java:1790) ~ [spring-beansE-5.2.9.REL .9.RELEASE] ... 17 общих кадров пропущено Процесс завершен с кодом выхода 1 - person VigSank; 06.10.2020