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

本文共 3842 字,大约阅读时间需要 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
@Slf4j
public 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)
@ResponseBody
public R error(GuliException e) {
log.error(ExceptionUtil.getMessage(e));
return R.error().message(e.getMessage()).code(e.getCode());
}

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

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

你可能感兴趣的文章
NodeSession:高效且灵活的Node.js会话管理工具
查看>>
node~ http缓存
查看>>
node不是内部命令时配置node环境变量
查看>>
node中fs模块之文件操作
查看>>
Node中同步与异步的方式读取文件
查看>>
node中的get请求和post请求的不同操作【node学习第五篇】
查看>>
Node中的Http模块和Url模块的使用
查看>>
Node中自启动工具supervisor的使用
查看>>
Node入门之创建第一个HelloNode
查看>>
node全局对象 文件系统
查看>>
Node出错导致运行崩溃的解决方案
查看>>
Node响应中文时解决乱码问题
查看>>
node基础(二)_模块以及处理乱码问题
查看>>
node安装卸载linux,Linux运维知识之linux 卸载安装node npm
查看>>
node安装及配置之windows版
查看>>
Node实现小爬虫
查看>>
Node提示:error code Z_BUF_ERROR,error error -5,error zlib:unexpected end of file
查看>>
Node提示:npm does not support Node.js v12.16.3
查看>>
Node搭建静态资源服务器时后缀名与响应头映射关系的Json文件
查看>>
Node服务在断开SSH后停止运行解决方案(创建守护进程)
查看>>