前言
最近做一个项目,自定义了全局异常处理,但是返回值一直无法返回自定义的类型。
调试了一早上,气到吐血。终于发现问题了。
自定义异常处理
/**
* @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”,“登录过期“)
BizException 是自定义异常类
这个看似没有问题。但是postman测试的返回结果:
{
"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"
}
很难受!!!
经过一早上的各种调试,终于发现了问题所在。
问题所在
程序补抓到异常抛出,然后全局的自定义异常处理类会捕获,对异常进行处理,必须通过@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流程,看他异常从哪里抛出,返回结果是哪儿来的,才能找到问题。