在 Spring Boot App 中启动 ApplicationContext 时出错

Posted

技术标签:

【中文标题】在 Spring Boot App 中启动 ApplicationContext 时出错【英文标题】:Error starting ApplicationContext in Spring Boot App 【发布时间】:2017-09-23 09:15:55 【问题描述】:

我正在尝试使用简单的 Spring Boot 应用程序。我在 ApplicationContext 上启动应用程序时遇到问题。

2017-04-26 11:17:31.101 WARN 14528 --- [main] scaAnnotationConfigApplicationContext:上下文初始化期间遇到异常 - 取消刷新尝试:org.springframework.beans.factory.UnsatisfiedDependencyException:创建名为“的 bean 时出错”类路径资源中定义的standardJacksonObjectMapperBuilderCustomizer' [org/springframework/boot/autoconfigure/jackson/JacksonAutoConfiguration$Jackson2ObjectMapperBuilderCustomizerConfiguration.class]:通过方法'standardJacksonObjectMapperBuilderCustomizer'参数1表示的不满足的依赖关系;嵌套异常是 org.springframework.beans.factory.BeanCreationException:创建名称为“spring.jackson-org.springframework.boot.autoconfigure.jackson.JacksonProperties”的 bean 时出错:bean 初始化失败;嵌套异常是 javax.validation.ValidationException:无法创建配置,因为找不到 Bean 验证提供程序。将像 Hibernate Validator (RI) 这样的提供程序添加到您的类路径中。 2017-04-26 11:17:31.116 信息 14528 --- [主要] utoConfigurationReportLoggingInitializer:

启动 ApplicationContext 时出错。要显示自动配置报告,请在启用“调试”的情况下重新运行您的应用程序。 2017-04-26 11:17:31.121 错误 14528 --- [主要] o.s.b.d.LoggingFailureAnalysisReporter:

我在启动应用程序时遇到了上述错误。我使用的是 spring boot 1.5.1.RELEASE 版本。

请做有需要的。

编辑 1

编辑 2

package com.hello;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class HelloWorld

public static void main(String[] args) 
    // TODO Auto-generated method stub
    SpringApplication.run(HelloWorld.class, args);



【问题讨论】:

你读过异常吗? Unable to create a Configuration, because no Bean Validation provider could be found. Add a provider like Hibernate Validator (RI) to your classpath 对我来说很清楚。 是的。面临这个异常。 阅读这条消息,它给出了解决方案……它再清楚不过了。 Hibernate-validator 和 validation-api jar 被添加到类路径中。它显示相同的错误。 不是根据启动它的服务器... 【参考方案1】:

Jackson 库似乎不适用于此引导项目。 手动添加 Jackson 库或添加以下将在内部导入 Jackson 库的依赖项。

<?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>

    <name>helloWorld</name>
    <version>0.0.0-SNAPSHOT</version>
    <groupId>com.test</groupId>
    <artifactId>test</artifactId>

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

    <packaging>jar</packaging>

    <properties>
        <dozer.version>5.4.0</dozer.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-feign</artifactId>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Camden.SR5</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.3</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>

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

【讨论】:

我在 pom.xml 中添加了 jackson-core、jackson-annotations、jackson-databind 依赖项,但仍然显示相同的错误。 嗨,Kumaresh,请使用start.spring.io 创建示例引导项目,它将自动添加所有需要的jar。希望对你有帮助。【参考方案2】:

我通过在 pom.xml 中排除 hibernate-validator 依赖项解决了这个问题。它运行良好,没有任何问题。

【讨论】:

【参考方案3】:

通过为 Jackson 添加以下依赖项解决了该问题:

<dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-autoconfigure</artifactId>
      <version>1.2.1.RELEASE</version> 
</dependency>

还要确保删除 Jackson 的类路径条目

【讨论】:

以上是关于在 Spring Boot App 中启动 ApplicationContext 时出错的主要内容,如果未能解决你的问题,请参考以下文章

无法在 Eclipse 中启动 Spring Boot App:无法启动嵌入式 Tomcat

Azure App Service - Spring Boot 应用程序在启动时卡住

Netflix Zuul注解导致spring boot app启动失败

从数据库加载spring boot app属性

将已有的spring app迁移到spring-boot,手动配置spring-boot?

为啥 Spring Boot web app 启动后会立即关闭?