Spring Boot 2.3.3.RELEASE解决ErrorController的getErrorPath的 @Deprecated,Spring Boot Whitelabel Error

本文介绍了在Spring Boot 2.3.3.RELEASE中,由于getErrorPath被@Deprecated,如何解决Whitelabel Error页面问题。文章提供了一种配置方式和代码样例,指导如何进行统一异常拦截,避免显示默认的Spring Boot错误页面。

使用背景

微服务项目当请求地址返回404和500异常的时候,希望统一拦截,而不是出现springboot 的Whitelabel Error。

使用方式

在springboot 2.3.0版本之前,可以使用实现ErrorController,然后自定义/error的url返回内容即可
如下图所票

@RestController
@RequestMapping("/error")
public class JsonErrorController extends AbstractErrorController {

    public JsonErrorController(final ErrorAttributes errorAttributes) {
        super(errorAttributes);
    }

    @GetMapping
    public ResponseEntity<Map<String, Object>> error(final HttpServletRequest request) {
        final Map<String, Object> body = this.getErrorAttributes(request, false);
        final HttpStatus status = this.getStatus(request);
        return new ResponseEntity<>(body, status);
    }

    @Override
    public String getErrorPath() {
        return "/error";
    }

}

springboot 2.3.0版本以后getErrorPath已经被标记为@Deprecated

SpringBoot 2.3.0+解决方案

1.写配置

#出现错误时, 直接抛出异常
spring:
  mvc:
    throw-exception-if-no-handler-found: true
  #不要为我们工程中的资源文件建立映射
  resources:
    add-mappings: false

这样就不会出现Whitelabel Error,交由@RestControllerAdvice处理

统一拦截

package vip.mate.core.web.handler;

import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.springframework.http.HttpStatus;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.servlet.NoHandlerFoundException;
import vip.mate.core.common.api.Result;
import vip.mate.core.common.exception.BaseException;
import vip.mate.core.common.exception.PreviewException;
import vip.mate.core.common.exception.TokenException;

import java.io.FileNotFoundException;

/**
 * Springboot WEB应用全局异常处理
 * @author pangu
 */
@Slf4j
@ResponseBody
@RestControllerAdvice
public class BaseExceptionHandler {

    /**
     * BaseException 异常捕获处理
     * @param ex 自定义BaseException异常类型
     * @return Result
     */
    @ExceptionHandler
    @ResponseStatus(HttpStatus.UNAUTHORIZED)
    public Result<?> handleException(BaseException ex) {
        log.error("程序异常:" + ex.toString());
        return Result.fail(HttpStatus.UNAUTHORIZED.value(), ex.getMessage());
    }

    /**
     * TokenException 异常捕获处理
     * @param ex 自定义TokenException异常类型
     * @return Result
     */
    @ExceptionHandler
    @ResponseStatus(HttpStatus.UNAUTHORIZED)
    public Result<?> handleException(TokenException ex) {
        log.error("程序异常==>errorCode:{}, exception:{}", HttpStatus.UNAUTHORIZED.value(), ex);
        return Result.fail(HttpStatus.UNAUTHORIZED.value(), ex.getMessage());
    }

    /**
     * FileNotFoundException,NoHandlerFoundException 异常捕获处理
     * @param exception 自定义FileNotFoundException异常类型
     * @return Result
     */
    @ExceptionHandler({FileNotFoundException.class, NoHandlerFoundException.class})
    public Result<?> noFoundException(Exception exception) {
        log.error("程序异常==>errorCode:{}, exception:{}", HttpStatus.NOT_FOUND.value(), exception);
        return Result.fail(HttpStatus.NOT_FOUND.value(), exception.getMessage());
    }

    /**
     * PreviewException 空指针异常捕获处理
     * @param ex 自定义PreviewException异常类型
     * @return Result
     */
    @ExceptionHandler
    @ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR)
    public Result<?> handleException(PreviewException ex) {
        log.error("程序异常:" + ex.toString());
        return Result.fail(HttpStatus.INTERNAL_SERVER_ERROR.value(), ex.getMessage());
    }

    /**
     * NullPointerException 空指针异常捕获处理
     * @param ex 自定义NullPointerException异常类型
     * @return Result
     */
    @ExceptionHandler
    @ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR)
    public Result<?> handleException(NullPointerException ex) {
        log.error("程序异常:{}" + ex.toString());
        return Result.fail(HttpStatus.INTERNAL_SERVER_ERROR.value(), ex.getMessage());
    }


    /**
     * 通用Exception异常捕获
     * @param ex 自定义Exception异常类型
     * @return Result
     */
    @ExceptionHandler
    @ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR)
    public Result<?> handleException(Exception ex) {
        log.error("程序异常:" + ex.toString());
        String message = ex.getMessage();
        if (StringUtils.contains(message, "Bad credentials")){
            message = "您输入的密码不正确";
        } else if (StringUtils.contains(ex.toString(), "InternalAuthenticationServiceException")) {
            message = "您输入的用户名不存在";
        }
        return Result.fail(HttpStatus.INTERNAL_SERVER_ERROR.value(), message);
    }
}

代码样例

https://github.com/matevip/matecloud

创建一个基于 Spring Boot 2.3.3.RELEASE 的详细项目可以分为以下几个步骤: ### 1. 环境准备 确保你的开发环境已经安装了以下工具: - **Java Development Kit (JDK) 8 或 11**:Spring Boot 2.3.3.RELEASE 支持 JDK 8 和 11。 - **Maven 3.x**:用于项目依赖管理和构建。 - **IDE(如 IntelliJ IDEA、Eclipse)**:推荐使用 IntelliJ IDEA 或 Eclipse 作为开发工具。 ### 2. 创建 Spring Boot 项目 可以通过以下几种方式创建 Spring Boot 项目: - **使用 Spring Initializr**:访问 [https://start.spring.io/](https://start.spring.io/),选择以下选项: - **Project**: Maven - **Language**: Java - **Spring Boot Version**: 2.3.3.RELEASE - **Dependencies**: 可以根据需要选择依赖,例如 `Spring Web`, `Spring Data JPA`, `Thymeleaf` 等。 点击 "Generate" 下载项目压缩包,解压后导入到 IDE 中。 - **手动创建 Maven 项目**:如果选择手动创建,可以在 `pom.xml` 文件中配置 Spring Boot 的依赖。 ### 3. 配置 `pom.xml` 在项目的 `pom.xml` 文件中,确保 `parent` 部分指向 Spring Boot 2.3.3.RELEASE: ```xml <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.3.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> ``` 添加所需的依赖,例如: ```xml <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> ``` ### 4. 创建主类 创建一个主类来启动 Spring Boot 应用程序。例如: ```java import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class SpringBoot233Application { public static void main(String[] args) { SpringApplication.run(SpringBoot233Application.class, args); } } ``` ### 5. 配置应用程序 在 `src/main/resources/application.properties` 或 `application.yml` 中配置应用程序的属性。例如,配置端口号和数据库连接: ```properties server.port=8080 spring.datasource.url=jdbc:mysql://localhost:3306/your_database spring.datasource.username=root spring.datasource.password=your_password spring.jpa.hibernate.ddl-auto=update ``` ### 6. 开发业务逻辑 根据项目需求,开发相应的业务逻辑。可以创建 `Controller`, `Service`, `Repository` 和 `Entity` 类来实现功能。 ### 7. 运行和测试 通过 IDE 运行主类 `SpringBoot233Application`,或者使用 Maven 命令启动项目: ```bash mvn spring-boot:run ``` 访问 `http://localhost:8080` 来测试你的 Spring Boot 应用程序。 ### 8. 打包和部署 使用 Maven 打包项目: ```bash mvn clean package ``` 生成的 JAR 文件位于 `target/` 目录下,可以通过以下命令运行: ```bash java -jar your-project-name.jar ``` ###
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值