Как исправить ошибку создания бина с именем requestMappingHandlerMapping - PullRequest
0 голосов
/ 13 апреля 2019

Я создаю веб-приложение с использованием Spring-Boot с конфигурацией на основе аннотаций.

Сначала я создал весеннее приложение с конфигурацией на основе аннотаций, используя Hibernate и JPA. Это работало нормально, но тогда мне нужно было добавить spring-boot к моему приложению, и теперь я не могу его запустить. Вот код:

@SpringBootApplication
@EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class})
public class Runner {

    public static void main(String[] args) {
        SpringApplication.run(Runner.class, args);
    }
}
@Configuration
@EnableTransactionManagement
@ComponentScans(value = { @ComponentScan("com.alex.pharm.dao"),
        @ComponentScan("com.alex.pharm.service") })
public class AppConfig {
    @Bean
    public LocalEntityManagerFactoryBean geEntityManagerFactoryBean() {
        LocalEntityManagerFactoryBean factoryBean = new LocalEntityManagerFactoryBean();
        factoryBean.setPersistenceUnitName("LOCAL_PERSISTENCE");
        return factoryBean;
    }

    @Bean
    @ConditionalOnMissingBean(type = "JpaTransactionManager")
    public JpaTransactionManager geJpaTransactionManager() {
        JpaTransactionManager transactionManager = new JpaTransactionManager();
        transactionManager.setEntityManagerFactory(geEntityManagerFactoryBean().getObject());
        return transactionManager;
    }
}
@RestController
public class HelloController {

    @RequestMapping("/")
    public String index() {
        return "Greetings from Spring Boot!";
    }
}
    <groupId>com.sachatol.pharmacy</groupId>
    <artifactId>pharmacyWebStore</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>jar</packaging>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.5.RELEASE</version>
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.1</version>
        </dependency><!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.13</version>
        </dependency>
        <!-- Hibernate 5.2.9 Final -->
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
            <version>5.2.9.Final</version>
        </dependency>

        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>4.3.7.RELEASE</version>
        </dependency>
        <!-- Spring ORM -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-orm</artifactId>
            <version>4.3.7.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-dbcp2</artifactId>
            <version>2.1.1</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
    </dependencies>


    <build>
        <sourceDirectory>src/main/java</sourceDirectory>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

Но когда я пытаюсь запустить его, я получаю следующее исключение:

ConfigServletWebServerApplicationContext : Exception encountered during context initialization
 - cancelling refresh attempt:org.springframework.beans.factory.BeanCreationException: 
Error creating bean with name 'requestMappingHandlerMapping' 
defined in class path resource
 [org/springframework/boot/autoconfigure/web/servlet/WebMvcAutoConfiguration$EnableWebMvcConfiguration.class]: 
Initialization of bean failed; nested exception is java.lang.NoSuchMethodError: 
org.springframework.web.servlet.handler.AbstractHandlerMapping.obtainApplicationContext()
Lorg/springframework/context/ApplicationContext;

Как я могу это исправить?

Ответы [ 3 ]

0 голосов
/ 13 апреля 2019

В отображении вашего запроса вы неправильно использовали:
@RequestMapping("/")

Вместо этого используйте это отображение, чтобы указать конечную точку и метод запроса следующим образом: @RequestMapping(value = "/", method = RequestMethod.GET)

Надеюсь, это решит вашу проблему.

0 голосов
/ 13 апреля 2019

Обнаружена проблема - я использовал старую версию для spring-context в pom (4.3.7.RELEASE), которая переопределяет ту, которая есть у spring-boot, и была причиной NoSuchMethodError. Таким образом, зависимость Spring-context была устаревшей и устаревшей после удаления или изменения ее на более новую версию (5.0.3), приложение нормально запускалось

0 голосов
/ 13 апреля 2019

Ваш @ RequestMapping , кажется, не хватает некоторых частей, попробуйте что-то вроде этого:

@RequestMapping(value = "/", method = RequestMethod.GET)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...