SpringBoot统一异常处理

本文详细介绍了如何在SpringBoot应用中使用@ControllerAdvice和@RestControllerAdvice注解实现异常处理,包括自定义处理不同类型的异常,如ServiceException,并展示了如何在控制器中引发这些异常进行测试。

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

概述

​ SpringBoot 提供了 @ControllerAdvice 、@RestControllerAdvice 注解可以实现统一异常处理,只需要在定义异常类加上以上注解即可。

自定义异常处理

定义统一异常处理

@RestControllerAdvice
public class GlobalExceptionHandler {

    private Logger logger = LoggerFactory.getLogger(getClass());

    /**
     *  拦截Exception类的异常
     * @param e
     * @return
     */
    @ExceptionHandler(Exception.class)
    @ResponseBody
    public Map<String,Object> exceptionHandler(Exception e){
        logger.error("系统异常Exception===",e);
        Map<String,Object> result = new HashMap<String,Object>();
        result.put("respCode", "9999");
        result.put("respMsg", "怎么又出错了");
        return result;
    }

    /**
     * 拦截 ServiceException 的异常
     * @param ex
     * @return
     */
    @ExceptionHandler(ServiceException.class)
    @ResponseBody
    public Map<String,Object> exceptionHandler(ServiceException ex){
        logger.info("自定义异常ServiceException:{}({})",ex.getMsg(), ex.getCode());
        Map<String,Object> result = new HashMap<String,Object>();
        result.put("respCode", ex.getCode());
        result.put("respMsg", ex.getMsg());
        return result;
    }

}

创建 controller 类

@RestController
@RequestMapping("/ex")
public class ExceptionController {

    private Logger logger = LoggerFactory.getLogger(getClass());

    @RequestMapping("/testEx")
    public String testEx() {
        logger.debug("testEx>>>>>>");
        throw new ServiceException("501","自定义ServiceException异常");
    }

    @RequestMapping("/testEx1")
    public String testEx1() {
        logger.debug("testEx1>>>>>>");
        int a = 1/0;
        return "sucesss";
    }

    @RequestMapping("/test")
    public String test() {
        logger.debug("test>>>>>>");
        return "sucesss";
    }
}

测试异常

http://127.0.0.1:8080/ex/test 正常访问

http://127.0.0.1:8080/ex/testEx 自定义异常

http://127.0.0.1:8080/ex/testEx1 系统异常

tomcat further occurrences of HTTP header parsing errors will be logged at DEBUG level.

原访问地址: http://localhost:8080/ex/test

改为:http://127.0.0.1:8080/ex/test

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值