SpringBoot全局異常處理之解決404/500錯誤
前言
SpringBoot要全局處理 Spring Boot 應用程序中的 HTTP 404 和 500 錯誤,您可以自定義一個異常處理器類,并使用 @ControllerAdvice
和 @ExceptionHandler
注釋來攔截和處理這些異常。
解決方案
下面是一種可能的實現(xiàn)方式,它捕獲HTTP GET請求中PathVariable
參數(shù)類型不匹配、參數(shù)格式錯誤以及其他所有未處理的異常,并返回一個包含錯誤代碼和錯誤消息的 Map 對象:
@ControllerAdvice public class GlobalExceptionHandler { // 捕獲 PathVariable 參數(shù)類型不匹配或格式錯誤的異常,并返回錯誤信息 @ExceptionHandler(MethodArgumentTypeMismatchException.class) @ResponseStatus(HttpStatus.BAD_REQUEST) @ResponseBody public Map<String, Object> handleMethodArgumentTypeMismatchException(MethodArgumentTypeMismatchException ex) { return createErrorResponse(HttpStatus.BAD_REQUEST.value(), "請求參數(shù)有誤: " + ex.getMessage()); } // 捕獲其他未處理的異常,并返回錯誤信息 @ExceptionHandler(Exception.class) @ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR) @ResponseBody public Map<String, Object> handleUncaughtException(Exception ex) { return createErrorResponse(HttpStatus.INTERNAL_SERVER_ERROR.value(), "系統(tǒng)內(nèi)部錯誤: " + ex.getMessage()); } // 創(chuàng)建包含錯誤碼和錯誤消息的 Map 對象 private Map<String, Object> createErrorResponse(int code, String message) { Map<String, Object> errorResponse = new HashMap<>(); errorResponse.put("code", code); errorResponse.put("message", message); return errorResponse; } }
說明:
在此示例中:
- 使用
@ControllerAdvice
和@ExceptionHandler
注釋標識此類為全局異常處理程序,并捕獲了MethodArgumentTypeMismatchException
和任何其他未處理的異常。 - 使用
@ResponseStatus(HttpStatus.BAD_REQUEST)
和@ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR)
來指定異常的 HTTP 響應狀態(tài)碼。 - 使用
@ResponseBody
注釋來告訴 Spring Boot 應用程序,我們不想呈現(xiàn)采用模板引擎進行渲染的視圖,而是返回具體的響應正文對象。createErrorResponse()
方法創(chuàng)建并返回包含錯誤代碼和錯誤消息的 Map 對象。
通用的全局異常處理
@ControllerAdvice public class GlobalExceptionHandler { /** * 處理 HTTP 404 錯誤 */ @ExceptionHandler(NoHandlerFoundException.class) @ResponseStatus(HttpStatus.NOT_FOUND) @ResponseBody public ApiError handleNotFound(HttpServletRequest req, Exception ex) { return new ApiError(HttpStatus.NOT_FOUND.value(), "無該資源: " + req.getRequestURI()); } /** * 處理 HTTP 500 錯誤 */ @ExceptionHandler(Exception.class) @ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR) @ResponseBody public ApiError handleInternalServerError(HttpServletRequest req, Exception ex) { return new ApiError(HttpStatus.INTERNAL_SERVER_ERROR.value(), "服務器內(nèi)部錯誤: " + ex.getMessage()); } /** * 處理用戶登錄異常 */ @ExceptionHandler(UserLoginException.class) @ResponseStatus(HttpStatus.UNAUTHORIZED) @ResponseBody public ApiError handleUserLoginException(HttpServletRequest req, UserLoginException ex) { return new ApiError(HttpStatus.UNAUTHORIZED.value(), "用戶登錄失敗: " + ex.getMessage()); } /** * 處理其他所有未處理的異常 */ @ExceptionHandler(Throwable.class) @ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR) @ResponseBody public ApiError handleOtherExceptions(HttpServletRequest req, Throwable ex) { return new ApiError(HttpStatus.INTERNAL_SERVER_ERROR.value(), "系統(tǒng)內(nèi)部錯誤: " + ex.getMessage()); } }
觸發(fā)異常
我們在控制器中模擬一個用戶登錄失敗的場景,并將 UserLoginException 拋出:
@RestController public class UserController { @Autowired private UserService userService; @PostMapping("/login") public String login(@RequestBody LoginForm form) { // 驗證用戶名和密碼 if (!userService.validate(form.getUsername(), form.getPassword())) { // 用戶不存在或密碼錯誤,拋出 UserLoginException 異常 throw new UserLoginException("用戶名或密碼不正確"); } // 登錄成功,返回 token 或用戶信息 // ...... } }
總結(jié)
到此這篇關(guān)于SpringBoot全局異常處理之解決404/500錯誤的文章就介紹到這了,更多相關(guān)SpringBoot解決404 500錯誤內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java8中List轉(zhuǎn)Map(Collectors.toMap) 的技巧分享
在最近的工作開發(fā)之中,慢慢習慣了很多Java8中的Stream的用法,很方便而且也可以并行的去執(zhí)行這個流,這篇文章主要給大家介紹了關(guān)于Java8中List轉(zhuǎn)Map(Collectors.toMap) 的相關(guān)資料,需要的朋友可以參考下2021-07-07SpringCloud消息總線Bus配置中心實現(xiàn)過程解析
這篇文章主要介紹了SpringCloud消息總線Bus配置中心實現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-03-03詳解WebSocket+spring示例demo(已使用sockJs庫)
本篇文章主要介紹了WebSocket spring示例demo(已使用sockJs庫),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-01-01使用SpringBoot Actuator監(jiān)控應用示例
Actuator是Spring Boot提供的對應用系統(tǒng)的自省和監(jiān)控的集成功能,可以對應用系統(tǒng)進行配置查看、相關(guān)功能統(tǒng)計等。這篇文章主要介紹了使用SpringBoot Actuator監(jiān)控應,有興趣的可以了解一下2018-05-05Redisson分布式閉鎖RCountDownLatch的使用詳細講解
分布式鎖和我們java基礎(chǔ)中學習到的synchronized略有不同,synchronized中我們的鎖是個對象,當前系統(tǒng)部署在不同的服務實例上,單純使用synchronized或者lock已經(jīng)無法滿足對庫存一致性的判斷。本次主要講解基于rediss實現(xiàn)的分布式鎖2023-02-02springBoot使用openfeign來遠程調(diào)用的實現(xiàn)
這篇文章主要介紹了springBoot使用openfeign來遠程調(diào)用的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03