Spring @ExceptionHandler注解統(tǒng)一異常處理和獲取方法名
摘要:
在 Spring Boot 中,使用Spring注解@ControllerAdvice 和 @ExceptionHandler 統(tǒng)一處理異常,并捕獲方法名,從而快速定位錯誤原因。
背景分析
最近走查線上環(huán)境日志時,發(fā)現(xiàn)打印了很多org.springframework.web.HttpRequestMethodNotSupportedException: Request method 'GET' not supported
異常日志,雖然知道是因為接口不支持GET請求導(dǎo)致的,但是,定位不到是因為錯誤調(diào)用哪個接口導(dǎo)致,給人很大困惑。
@ExceptionHandler介紹
異常處理器@ExceptionHandler是Spring MVC框架中用于處理異常的注解,方法名按需自定義,方法參數(shù)可以是Exception及其子類對象、HttpServletRequest、HttpServletResponse等,系統(tǒng)會自動為它們賦值。方法返回值類型可以為ModelAndView、Model、Map、View、String以及void等。它的作用是把各個Controller中拋出的異常集中到一個類中處理。
在被@ControllerAdvice或者@RestControllerAdvice修飾的類里,可以使用@ExceptionHandler捕捉異常,返回值類型為Map的示例如下:
@Slf4j @RestControllerAdvice public class GlobalExceptionAdvice { /* * 捕捉HTTP請求方式異常HttpRequestMethodNotSupportedException */ @ExceptionHandler(HttpRequestMethodNotSupportedException.class) public Map<String, Object> handleBadMethodException(HttpRequestMethodNotSupportedException exception, HttpServletRequest req) { log.error("不支持的請求方式:{}-{}", req.getRequestURI(), exception.getMessage()); Map<String, Object> result=new HashMap(); result.put("msg","不支持的請求方式"); result.put("code", HttpStatus.METHOD_NOT_ALLOWED.value()); return result; } }
@RestControllerAdvice:放在類的上面,表示這個類中有異常處理器,它是基于AOP的、對控制器類的一個增強(qiáng)。
req.getRequestURI()
用于獲取當(dāng)前API訪問路徑的URI,里面包含方法名,用于快速定位是哪個API出錯。
在上述異常處理器示例中,當(dāng)控制層拋出HttpRequestMethodNotSupportedException異常時,handleBadMethodException方法會被調(diào)用,返回一個包含錯誤信息的Map對象。如果把@ExceptionHandler(HttpRequestMethodNotSupportedException.class)改為@ExceptionHandler(Exception.class),則是處理全局異常了,會捕獲所有未被其它方法處理的異常,這樣處理的缺點是異常太過寬泛,不利于排查問題。
驗證功能的方法很簡單,請使用GET請求訪問僅支持POST請求的函數(shù),此時,控制臺將打印如下信息:
不支持的請求方式:/wiener/XXXMethod-Request method 'GET' not supported
結(jié)束語
Spring MVC的@ExceptionHandler注解為Web應(yīng)用程序提供了便捷的異常處理機(jī)制。通過使用該注解,可以在控制器中捕獲和處理特定類型的異常,提供友好的錯誤信息給用戶。在實際項目中,合理使用@ExceptionHandler能夠提高代碼的可維護(hù)性和用戶體驗。通過本文的解析和實踐,讀者可以更好地理解和掌握@ExceptionHandler的用法和原理。
到此這篇關(guān)于Spring注解之@ExceptionHandler 統(tǒng)一異常處理和獲取方法名的文章就介紹到這了,更多相關(guān)Spring @ExceptionHandler 統(tǒng)一異常處理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Spring中的@ExceptionHandler注解統(tǒng)一異常處理詳解
- SpringMVC使用@ExceptionHandler注解在Controller中處理異常
- Spring的異常處理@ExceptionHandler注解解析
- 關(guān)于SpringBoot使用@ExceptionHandler注解局部異常處理
- Spring中@ExceptionHandler注解的使用方式
- Spring中@ExceptionHandler注解的工作原理詳解
- Spring中的@ControllerAdvice和@ExceptionHandler注解處理全局異常
- Spring中的@ExceptionHandler注解詳解與應(yīng)用示例
相關(guān)文章
Java Date類常用示例_動力節(jié)點Java學(xué)院整理
在JDK1.0中,Date類是唯一的一個代表時間的類,但是由于Date類不便于實現(xiàn)國際化,所以從JDK1.1版本開始,推薦使用Calendar類進(jìn)行時間和日期處理。這里簡單介紹一下Date類的使用,需要的朋友可以參考下2017-05-05