博客
关于我
springboot统一异常处理
阅读量:584 次
发布时间:2019-03-11

本文共 3752 字,大约阅读时间需要 12 分钟。

Spring Boot 统一异常处理实践指南

在软件开发过程中,异常处理是保障系统稳定运行的重要环节。通过统一异常处理,我们可以将系统中出现的各种异常进行集中管理和处理,从而实现对异常状态的快速响应和定位。

制造异常情景

为了更好地理解异常处理的重要性,我们可以先通过制造特定的异常情景来观察系统的反应。例如,在业务逻辑中引入一个标记字段 @TableField(value = "is_deleted")private Boolean deleted;,并在需要的位置抛出异常。这个标记字段通常用于表示记录是否被逻辑删除。

创建异常处理工具类

guli-framework-common 模块的 com.guli.common.util 包中,我们创建了一个异常处理工具类 ExceptionUtil.java

public class ExceptionUtil {    public static String getMessage(Exception e) {        StringWriter sw = null;        PrintWriter pw = null;        try {            sw = new StringWriter();            pw = new PrintWriter(sw);            e.printStackTrace(pw);            pw.flush();            sw.flush();        } finally {            if (sw != null) {                try {                    sw.close();                } catch (IOException e1) {                    e1.printStackTrace();                }            }            if (pw != null) {                pw.close();            }        }        return sw.toString();    }}

这个工具类能够将异常信息转换为易于阅读和处理的字符串形式,便于日志记录和前端显示。

全局异常处理器

guli-framework-common 模块的 com.guli.common.handler 包中,我们创建了一个全局异常处理类 GlobalExceptionHandler.java

package com.guli.common.handler;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.http.HttpStatus;import org.springframework.web.bind.annotation.ControllerAdvice;import org.springframework.web.bind.annotation.ResponseBody;import java.util.HashMap;import java.util.Map;@ControllerAdvice@Slf4jpublic class GlobalExceptionHandler {    private static final Logger log = LoggerFactory.getLogger(GlobalExceptionHandler.class);    @ExceptionHandler(Exception.class)    @ResponseBody    public R error(Exception e) {        log.error(ExceptionUtil.getMessage(e));        return R.error();    }    @ExceptionHandler(BadSqlGrammarException.class)    @ResponseBody    public R error(BadSqlGrammarException e) {        log.error(ExceptionUtil.getMessage(e));        return R.setResult(ResultCodeEnum.BAD_SQL_GRAMMAR);    }    @ExceptionHandler(HttpMessageNotReadableException.class)    @ResponseBody    public R error(HttpMessageNotReadableException e) {        log.error(ExceptionUtil.getMessage(e));        return R.setResult(ResultCodeEnum.JSON_PARSE_ERROR);    }    @ExceptionHandler(GuliException.class)    @ResponseBody    public R error(GuliException e) {        log.error(ExceptionUtil.getMessage(e));        return R.error().message(e.getMessage()).code(e.getCode());    }}

这个类通过 @ControllerAdvice 注解,能够统一拦截所有定义的异常类型,并通过 @ResponseBody 返回适当的响应对象。

自定义异常类

为了满足业务需求的特殊性,我们在 com.guli.common.exception 包中创建了一个通用的自定义异常类 GuliException.java

package com.guli.common.exception;import io.swagger.annotations.ApiModel;import io.swagger.annotations.ApiProperty;import org.springframework.lang.annotation.ApiResponseObject;@ApiModel(value = "全局异常")public class GuliException extends RuntimeException {    @ApiProperty(value = "状态码")    private Integer code;    @ApiProperty(value = "错误信息")    private String message;    public GuliException(Integer code, String message) {        super(message);        this.code = code;    }    public GuliException(ResultCodeEnum resultCodeEnum) {        super(resultCodeEnum.getMessage());        this.code = resultCodeEnum.getCode();    }    @Override    public String toString() {        return "GuliException{" +               "code=" + code +               ",message=" + this.getMessage() +               '}';    }}

这个自定义异常类继承自 RuntimeException,具有无侵入性,同时支持状态码和错误信息的携带,便于统一处理和前端展示。

业务中的异常抛出

在业务逻辑中,我们需要在需要拦截异常的地方声明处理方法。例如:

@ExceptionHandler(GuliException.class)@ResponseBodypublic R error(GuliException e) {    log.error(ExceptionUtil.getMessage(e));    return R.error().message(e.getMessage()).code(e.getCode());}

通过这种方式,我们可以集中管理系统中出现的各种异常,实现对异常状态的快速响应和定位。

转载地址:http://gjgvz.baihongyu.com/

你可能感兴趣的文章
Navicat向sqlserver中插入数据时提示:当 IDENTITY_INSERT 设置为 OFF 时,不能向表中的标识列插入显式值
查看>>
Navicat因导入的sql文件中时间数据类型有参数而报错的原因(例:datetime(3))
查看>>
Navicat如何连接MySQL
查看>>
navicat导入.sql文件出错2006- MySQLserver has gone away
查看>>
Navicat导入海量Excel数据到数据库(简易介绍)
查看>>
Navicat工具Oracle数据库复制 or 备用、恢复功能(评论都在谈论需要教)
查看>>
Navicat工具中建立数据库索引
查看>>
navicat工具查看MySQL数据库_表占用容量_占用空间是多少MB---Linux工作笔记048
查看>>
navicat怎么导出和导入数据表
查看>>
Navicat怎样同步两个数据库中的表
查看>>
Navicat怎样筛选数据
查看>>
Navicat报错connection is being used
查看>>
Navicat报错:1045-Access denied for user root@localhost(using passwordYES)
查看>>
Navicat控制mysql用户权限
查看>>
navicat操作mysql中某一张表后, 读表时一直显示正在载入,卡死不动,无法操作
查看>>
Navicat连接mysql 2003 - Can't connect to MySQL server on ' '(10038)
查看>>
Navicat连接mysql数据库中出现的所有问题解决方案(全)
查看>>
Navicat连接Oracle出现Oracle library is not loaded的解决方法
查看>>
Navicat连接Oracle数据库以及Oracle library is not loaded的解决方法
查看>>
Navicat连接sqlserver提示:未发现数据源名并且未指定默认驱动程序
查看>>