统一异常处理@ControllerAdvice+@ExceptionHandler

本文介绍了一种统一异常处理策略,包括自定义异常类型、错误代码和信息,通过SpringMVC框架捕获并处理预知与不可预知异常,确保系统稳定性和用户体验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

统一异常处理
一、对异常的处理使用统一的异常处理流程:
1、自定义异常类型。
2、自定义错误代码及错误信息。
3、对于可预知的异常由程序员在代码中主动抛出,由SpringMVC统一捕获。 可预知异常是程序员在代码中手动抛出本系统定义的特定异常类型,由于是程序员抛出的异常,通常异常信息比较 齐全,程序员在抛出时会指定错误代码及错误信息,获取异常信息也比较方便。
4、对于不可预知的异常(运行时异常)由SpringMVC统一捕获Exception类型的异常。 不可预知异常通常是由于系统出现bug、或一些不要抗拒的错误(比如网络中断、服务器宕机等),异常类型为 RuntimeException类型(运行时异常)。
5、可预知的异常及不可预知的运行时异常最终会采用统一的信息格式(错误代码+错误信息)来表示,最终也会随请求响应给客户端。

二、抛出及处理流程:

在这里插入图片描述
1、在controller、service、dao中程序员抛出自定义异常;springMVC框架抛出框架异常类型
2、统一由异常捕获类捕获异常,并进行处理 。
3、获到自定义异常则直接取出错误代码及错误信息,响应给用户。
4、捕获到非自定义异常类型首先从Map中找该异常类型是否对应具体的错误代码,如果有则取出错误代码和错误 信息并响应给用户,如果从Map中找不到异常类型所对应的错误代码则统一为99999错误代码并响应给用户。
5、将错误代码及错误信息以Json格式响应给用户。
三、可预知异常处理
1.自定义异常类
public class CustomException extends RuntimeException {
//错误代码接口
private ResultCode resultCode;
public CustomException(ResultCode resultCode){
this.resultCode = resultCode;
}
public ResultCode getResultCode(){
return this.resultCode;
}
}
2. 异常捕获类
@ControllerAdvice
public class ExceptionCatch {
private static final Logger LOGGER = LoggerFactory.getLogger(ExceptionCatch.class);

@ExceptionHandler(CustomException.class)
@ResponseBody
public ResponseResult customException(CustomException e){
    LOGGER.error("catch exception : {}\r\n exception:",e.getMessage(),e);
    ResultCode resultCode = e.getResultCode();
    return new ResponseResult(resultCode);
}

}
@ControllerAdvice:使用该注解定义全局异常处理类
@ExceptionHandler: 统一处理某类异常
遇见错误:没有捕捉到异常
原因:spring注解扫描没有配置扫描该异常处理类所在的包,添加扫描即可。

四、不可预知异常处理
以非法参数异常为例
org.springframework.http.converter.HttpMessageNotReadableExceptio
1、在通用错误代码类CommCode(该类实现了ResultCode接口)中配置非法参数异常
INVALID_PARAM(false,10003,“非法参数!”),

2、在异常捕获类中配置 HttpMessageNotReadableException 为非法参数异常。定义异常捕获方法,异常捕获类代码如下:
//使用EXCEPTIONS存放异常类型和错误代码的映射
//特点:一旦创建,不可改变,线程安全
private static ImmutableMap<Class<? extends Throwable>,ResultCode> EXCEPTIONS;
//使用builder来构建一个异常类型和错误代码的异常
protected static ImmutableMap.Builder<Class<? extends Throwable>,ResultCode> builder = ImmutableMap.builder();

static {
//在这里加入一些基础的异常类型判断
builder.put(HttpMessageNotReadableException.class,CommonCode.INVALID_PARAM);
}

@ExceptionHandler(Exception.class)
@ResponseBody
public ResponseResult exception(Exception e){
LOGGER.error(“catch exception : {}\r\n exception:”,e.getMessage(),e);

if(EXCEPTIONS==null){
    //为空,则构建
    EXCEPTIONS = builder.build();
}
//判断当前异常是否记录在map集合中
final ResultCode resultCode = EXCEPTIONS.get(e.getClass());

if(resultCode!=null){
    //不为空,则返回相应信息
    return new ResponseResult(resultCode);
}   else{
    //为空则返回固定信息
    return new ResponseResult(CommonCode.SERVER_ERROR);
}

}

ImmutableMap 的作用就是:可以让java代码也能够创建一个对象常量映射,来保存一些常量映射的键值对。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值