网上找了很多资料,说什么原因的都有,试了半天
后来才发现,是自己加了log的aop切面,所以exception半路就被劫道了!!!
问题出在下面这端注释的代码中
可以看到我用try catch 对proceed方法进行包裹,一旦目标方法异常,catch就会被这里捕捉到并抛出异常处理掉,所以无法向上抛出,更无法到达@ControllerAdvice的全局异常处理器中!
@Around("webLog()")
public Object arround(ProceedingJoinPoint pjp) throws Throwable {
// try {
// Object o = pjp.proceed();
// return o;
// } catch (Throwable e) {
// e.printStackTrace();
// return null;
// }
Object o = pjp.proceed();
return o;
}
根本原因请看下面这张图: