- 在前后端分离的时代,都是通过restfulApi进行交互的。后端只需要返回状态码和信息给前端就可以,但有一个小小的问题,就是如果程序抛出了异常,那么也需要以restfulApi风格来返回,这就涉及到了异常捕获,而springboot提供了一种很方便的方法。
- 其实就是通过ExceptionHandler和ControllerAdvice拦截错误异常,最后再通过ResponseBody向前端返回json数据。
- 上代码:
@ControllerAdvice
@Slf4j // lombok 插件 可直接使用如log.info...
public class AllExceptionHandler extends BaseController{
@ExceptionHandler(value = LoginException.class)
@ResponseBody
@ResponseStatus(value = HttpStatus.UNAUTHORIZED)
public Object exceptionHandler(){
return getFailResult(CommunityCode.LOGIN_TIME_OUT.getMsg());
}
@ExceptionHandler
@ResponseBody
public Object allExceptionHandler(Exception e){
log.info("================【开始打印异常信息】================");
log.error("具体错误信息:【"+e.getMessage()+"】");
int count = 0; //只打印15行的错误堆栈
for (StackTraceElement stackTraceElement : e.getStackTrace()) {
log.error(stackTraceElement.toString());
if(count++ > 13) break;
}
log.info("================【异常信息打印完毕】================");
if(e instanceof CommunityException) return getFailResult(((CommunityException) e).getCode(),e.getMessage());
if(e instanceof IllegalArgumentException || e instanceof IllegalStateException) return getFailResult(e.getMessage());
if(e instanceof PersistenceException || e instanceof BadSqlGrammarException) return getFailResult(CommunityCode.SQL_ERROR);
if(e instanceof NullPointerException) return getFailResult(CommunityCode.NULL_POINTER_ERROR);
return getFailResult(CommunityCode.OTHER_ERROR);
}
- exceptionHandler这个方法是专门捕获LoginException(是自己写得并且继承RunTimeException)的,因为应前端的要求,当用户登录超时的时候,HTTP的状态码要返回401,所以就单独拿出来写了,相当于是局部方法,所以 ExceptionHandler注解中是有参数的;而allExceptionHandler这个方法则没有参数,代表当局部方法没有捕捉到时才进入全局异常进行捕捉,在这里我只列举了4种异常。ps:如果想在控制台看到具体的异常信息必须手动打印,否则控制台将不会输出异常信息,我估计是因为异常已经被我们捕获了,所以就不会输出了。
- 最后还请各位大佬们如果有什么意见和错误指正的千万不要客气。
打开App,阅读手记
热门评论
baseController
BasicController是哪来的
试试RestControllerAdvice