现象
filter
中抛出的异常没有被全局异常处理器拦截
,直接返回的是浏览器错误,这样很不规范。
{
“timestamp”: “2024-07-12T10:11:55.355+08:00”,
“status”: 500,
“error”: “Internal Server Error”,
“message”: “”,
“path”: “/api/v1/orderSubscription”
}
原因
因为
全局异常处理器(@ControllerAdvice)
主要处理控制器(@Controller)
的异常,而filter是先于
控制器执行的,并且后续它们并不直接参与Spring MVC的异常处理机制。
解决
重新再抛出异常即可,利用
请求转发
。
1、filter中不直接抛出异常,而是做请求转发。
if (tonce == null){
//不能直接抛出异常,因为filter在全局异常处理器之前生效,直接抛出全局异常处理器会拦截不到
request.setAttribute("outputError",OutputExceptionEnum.NO_TONCE.getMessage());
request.getRequestDispatcher("/outputError/throw").forward(request,response);
return;
}
2、另写一个控制器方法接收请求,而后手动抛出异常。
@RestController
@RequestMapping("/outputError")
public class OutputExceptionController {
@PostMapping("/throw")
public OutputException handleOutputException(HttpServletRequest request){
String message = (String) request.getAttribute("outputError");
if (OutputExceptionEnum.NO_TONCE.getMessage().equals(message)){
throw new OutputException(OutputExceptionEnum.NO_TONCE.getMessage(),OutputExceptionEnum.NO_TONCE.getCode());
}else if (OutputExceptionEnum.TIMEOUT.getMessage().equals(message)){
throw new OutputException(OutputExceptionEnum.TIMEOUT.getMessage(),OutputExceptionEnum.TIMEOUT.getCode());
}else {
throw new OutputException(OutputExceptionEnum.OTHER.getMessage(),OutputExceptionEnum.OTHER.getCode());
}
}
}