Springboot如何統(tǒng)一處理Filter異常
Springboot統(tǒng)一處理Filter異常
由于Filter異常Spring MVC無法進(jìn)行統(tǒng)一處理,所以需要手動處理一下異常
定義一個Filter
這個Filter位于所有Filter的最前面,當(dāng)其他Filter發(fā)生異常,捕獲異常棧,然后轉(zhuǎn)發(fā)到ErrorController
@Slf4j
public class ExceptionFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
log.info("ex filter init .......");
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
// 是否已經(jīng)放有異常棧, 避免循環(huán)
boolean isRethrow = !Objects.isNull(request.getAttribute(Req.Attr.EX));
if (isRethrow) {
chain.doFilter(request, response);
return;
}
try {
chain.doFilter(request, response);
} catch (AbstractCustomException e) {
// 發(fā)生異常,保存異常棧
request.setAttribute(Req.Attr.EX, e);
request.getRequestDispatcher(UrlUtil.ERROR_RETHROW).forward(request, response);
}
}
@Override
public void destroy() {
}
}
注冊Filter為第一個
@Configuration
public class WebMvcConfig extends WebMvcConfigurerAdapter {
@Bean
public ExceptionFilter exceptionFilter() {
return new ExceptionFilter();
}
@Bean
public FilterRegistrationBean registerExceptionFilter() {
FilterRegistrationBean bean = new FilterRegistrationBean();
bean.setFilter(exceptionFilter());
bean.addUrlPatterns("/*");
bean.setOrder(1);
return bean;
}
ErrorController如下
@RestController
public class ErrorController {
@Resource
private HttpServletRequest request;
/**
* 重新拋出異常
*/
@RequestMapping("/error/rethrow")
public void rethrow() {
throw ((AbstractCustomException) request.getAttribute(Req.Attr.EX));
}
}
ErrorController拋出的異常會被Spring的全局異常處理捕獲
@Slf4j
@ControllerAdvice
public class GlobalExceptionHandler {
/**
* 登錄異常處理
* @param e 異常
* @return 處理結(jié)果
*/
@ExceptionHandler(LoginException.class)
@ResponseBody
public Result<String> loginExceptionHandler(LoginException e) {
OperatorContext.remove();
log.error("登錄異常", e);
return Result.loginError(e.getMessage());
}
/**
* 業(yè)務(wù)異常處理
* @param e 異常
* @return 處理結(jié)果
*/
@ExceptionHandler(BizException.class)
@ResponseBody
public Result<String> bizExceptionHandler(BizException e) {
log.error("業(yè)務(wù)異常", e);
return Result.error(e.getMessage());
}
@ExceptionHandler(LawlessInvokeException.class)
@ResponseBody
public Result<String> lawlessException(LawlessInvokeException e) {
log.error("@非法調(diào)用@", e);
return Result.error(e.getMessage());
}
/**
* 全局異常處理
* @param e 異常
* @return 處理結(jié)果
*/
@ExceptionHandler(Exception.class)
@ResponseBody
public Result<String> exceptionHandler(Exception e) {
log.error("服務(wù)器異常", e);
return Result.error("服務(wù)器異常");
}
這樣我們就可以在Filter中和其他地方一樣拋出異常了
總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Token登陸驗(yàn)證機(jī)制的原理及實(shí)現(xiàn)
這篇文章介紹了Token登陸驗(yàn)證機(jī)制的原理及實(shí)現(xiàn),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-12-12
SpringBoot3結(jié)合gRpc實(shí)現(xiàn)遠(yuǎn)程服務(wù)調(diào)用的流程步驟
gRPC是一個現(xiàn)代開源高性能遠(yuǎn)程過程調(diào)用(RPC)框架,可以在任何環(huán)境中運(yùn)行,它由Google開發(fā),旨在幫助開發(fā)人員更輕松地構(gòu)建分布式應(yīng)用,特別是當(dāng)代碼可能在不同地方運(yùn)行的時候,本文介紹了SpringBoot3結(jié)合gRpc實(shí)現(xiàn)遠(yuǎn)程服務(wù)調(diào)用的流程步驟,需要的朋友可以參考下2024-07-07
java案例實(shí)戰(zhàn)之字符串轉(zhuǎn)換為二進(jìn)制
最近遇到個需求,要求編寫一個程序,從鍵盤錄入一個字符串,將字符串轉(zhuǎn)換為二進(jìn)制數(shù),下面這篇文章主要給大家介紹了關(guān)于java字符串轉(zhuǎn)換為二進(jìn)制的相關(guān)資料,需要的朋友可以參考下2023-06-06
Java使用JNDI連接數(shù)據(jù)庫的實(shí)現(xiàn)方法
本文主要介紹了Java使用JNDI連接數(shù)據(jù)庫的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-12-12
Java之Rsync并發(fā)遷移數(shù)據(jù)并校驗(yàn)詳解
這篇文章主要介紹了Java之Rsync并發(fā)遷移數(shù)據(jù)并校驗(yàn)詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
DOM解析XML報(bào)錯Content is not allowed in prolog解決方案詳解
這篇文章主要介紹了DOM解析XML報(bào)錯解決方案詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10
springboot實(shí)現(xiàn)極驗(yàn)校驗(yàn)的項(xiàng)目實(shí)踐
在系統(tǒng)業(yè)務(wù)中,需要想客戶發(fā)送手機(jī)驗(yàn)證碼,進(jìn)行驗(yàn)證后,才能提交,本文主要介紹了springboot實(shí)現(xiàn)極驗(yàn)校驗(yàn)的項(xiàng)目實(shí)踐,具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09
詳解Java Bellman-Ford算法原理及實(shí)現(xiàn)
Bellman-Ford算法與Dijkstra算法類似,都是以松弛操作作為基礎(chǔ),Bellman-Ford算法是對所有邊都進(jìn)行松弛操作,本文將詳解Bellman-Ford算法原理及實(shí)現(xiàn),感興趣的可以了解一下2022-07-07

