您好,登錄后才能下訂單哦!
這篇文章給大家介紹怎么在Spring中利用Filter過濾器對全局異常處理進行配置,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
Spring下Filter過濾器配置全局異常處理
Filter中出現的異常,spring的全局異常處理器是無法捕獲的,所以filter攔截器中出現的異常會直接的拋向瀏覽器,在瀏覽器中顯示500錯誤。
而我當前的項目中,是在Filter中判斷用戶是否有攜帶Token訪問,如果沒有,則拋出異常,讓其做登錄操作。而且異常信息要處理成json格式返回給前端。這就很尷尬了。
好了廢話說多了,上解決方案:
結局方案:
Filter攔截器中直接拋出異常信息
@Component public class AdminAuthentiationFilter extends OncePerRequestFilter { private final String DEFAULTE_URI = "/api/admin/login"; @Override protected void doFilterInternal(HttpServletRequest req, HttpServletResponse resp, FilterChain filterChain) throws ServletException, IOException { String admin_token = req.getHeader("admin_token"); if(StrUtil.isBlank(admin_token) && !req.getRequestURI().equals(DEFAULTE_URI)){ //在攔截器中直接拋出一個異常 throw new LoginException("用戶未登錄,請先登錄!"); } filterChain.doFilter(req,resp); } }
第一步:在web.xml中配置錯誤頁,用于捕獲500狀態
<!-- 注冊過濾器--> <filter> <filter-name>myFilter</filter-name> <filter-class>com.fenkuan.support.filters.AdminAuthentiationFilter</filter-class> </filter> <filter-mapping> <filter-name>myFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!--捕獲500錯誤狀態--> <error-page> <error-code>500</error-code> <location>/500</location> </error-page>
第二步:編寫一個FilterException自定義異常類
public class FilterException extends RuntimeException{ private String data; public FilterException(String message) { super(message); } public FilterException(String message, String data) { super(message, data); this.data = data; } public String getData() { return data; } }
第三步:編寫一個用于處理500錯誤的controller
@RestController public class FilterErrorController { @RequestMapping("/500") public void filterError(HttpServletRequest req){ //獲取servlet請求中的異常屬性。該屬性下存儲了確切的錯誤信息。 Throwable t = (Throwable) req.getAttribute("javax.servlet.error.exception"); //創建一個filterException拋出,該異常會被全局異常處理類捕獲,并處理。 throw new FilterException(t.getMessage()); } }
第四步:編寫一個捕獲全局異常的異常處理類
//全局異常處理類 @RestControllerAdvice public class ControllerExceptionHandler{ @ExceptionHandler(FilterException.class) @ResponseStatus(HttpStatus.BAD_REQUEST) public BadException<?> filterException(FilterException e){ BadException<Object> objectBadException = handleExceptionObject(e); objectBadException.setStatus(HttpStatus.BAD_REQUEST.value()); objectBadException.setMessage(e.getMessage()); return objectBadException; } @ExceptionHandler(Exception.class) @ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR) public BadException<?> responseException(Exception e){ //異常兜底處理 BadException<?> objectBadException = handleExceptionObject(e); objectBadException.setStatus(HttpStatus.INTERNAL_SERVER_ERROR.value()); objectBadException.setMessage(HttpStatus.INTERNAL_SERVER_ERROR.getReasonPhrase()); return objectBadException; } // Throwable是Exception的父類,所以可以使用該類型來接受項目中拋出的所有異常,包括Exception即其子類。 private <T> BadException<T> handleExceptionObject(Throwable throwable){ BadException<T> bad = new BadException<>(); bad.setMessage(throwable.getMessage()); return bad; } }
BadException類,用于封裝要返會給前端的異常信息(這里使用了Lombok工具)
import lombok.Data; @Data public class BadException<T> { private Integer status; private String message; private Object data; private Object devData; }
結果:
關于怎么在Spring中利用Filter過濾器對全局異常處理進行配置就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。