自定义异常处理返回无效问题

前言

最近作一个项目,自定义了全局异常处理,可是返回值一直没法返回自定义的类型。 调试了一早上,气到吐血。终于发现问题了。html

自定义异常处理

/** * @author :Maolin * @className :GlobalExceptionHandler * @date :Created in 2019/9/2 9:08 * @description: 自定义全局异常处理 * @version: 1.0 */
@Slf4j
@ControllerAdvice
public class GlobalExceptionHandler {
    //private static final Logger logger = LoggerFactory.getLogger(GlobalExceptionHandler.class);

    /** * 处理自定义的业务异常 * @param req * @param e * @return */
    @ExceptionHandler(value = BizException.class)
    public UniversalResponseBody bizExceptionHandler(HttpServletRequest req, BizException e){
        log.error("发生业务异常!缘由是:{}",e.getErrorMsg());
        return UniversalResponseBody.error(e.getErrorCode(),e.getErrorMsg());
    }

    /** * 处理空指针的异常 * @param req * @param e * @return */
    @ExceptionHandler(value =NullPointerException.class)
    public UniversalResponseBody exceptionHandler(HttpServletRequest req, NullPointerException e){
        log.error("发生空指针异常!缘由是:",e);
        return UniversalResponseBody.error(CommonEnum.BODY_NOT_MATCH);
    }


    /** * 处理其余异常 * @param req * @param e * @return */
    @ExceptionHandler(value =Exception.class)
    public UniversalResponseBody exceptionHandler(HttpServletRequest req, Exception e){
        log.error("未知异常!缘由是:",e);
        return UniversalResponseBody.error(CommonEnum.INTERNAL_SERVER_ERROR);
    }
}
复制代码

抛出异常

在抛出异常的地方,throws new BizException(“600”,“登陆过时“)java

BizException 是自定义异常类spring

这个看似没有问题。可是postman测试的返回结果:post

{
    "timestamp": "2019-09-03T02:54:32.823+0000",
    "status": 404,
    "error": "Not Found",
    "message": "Token is illegal or expired",
    "trace": "com.xidian.reservation.exceptionHandler.BizException: Token is illegal or expired\r\n",
    "path": "/login/test"
}
复制代码

很难受!!!测试

通过一早上的各类调试,终于发现了问题所在。spa

问题所在

程序补抓到异常抛出,而后全局的自定义异常处理类会捕获,对异常进行处理,必须经过@ResponseBody注解返回JSON。指针

问题就是缺乏@ResponseBody注解,致使捕获的异常由spring自带的处理信息返回。调试

@Slf4j
@ControllerAdvice
public class GlobalExceptionHandler {
    //private static final Logger logger = LoggerFactory.getLogger(GlobalExceptionHandler.class);

    /** * 处理自定义的业务异常 * @param req * @param e * @return */
    @ResponseBody
    @ExceptionHandler(value = BizException.class)
    public UniversalResponseBody bizExceptionHandler(HttpServletRequest req, BizException e){
        log.error("发生业务异常!缘由是:{}",e.getErrorMsg());
        return UniversalResponseBody.error(e.getErrorCode(),e.getErrorMsg());
    }

    /** * 处理空指针的异常 * @param req * @param e * @return */
    @ResponseBody
    @ExceptionHandler(value =NullPointerException.class)
    public UniversalResponseBody exceptionHandler(HttpServletRequest req, NullPointerException e){
        log.error("发生空指针异常!缘由是:",e);
        return UniversalResponseBody.error(CommonEnum.BODY_NOT_MATCH);
    }


    /** * 处理其余异常 * @param req * @param e * @return */
    @ResponseBody
    @ExceptionHandler(value =Exception.class)
    public UniversalResponseBody exceptionHandler(HttpServletRequest req, Exception e){
        log.error("未知异常!缘由是:",e);
        return UniversalResponseBody.error(CommonEnum.INTERNAL_SERVER_ERROR);
    }
}
复制代码

小结

必定要熟悉他的AOP流程,看他异常从哪里抛出,返回结果是哪儿来的,才能找到问题。code

相关文章
相关标签/搜索