Spring Boot統一異常攔截實踐指南

Spring Boot統一異常攔截實踐指南

一、為什么需要統一異常處理

在Web應用開發中,異常處理是保證系統健壯性和用戶體驗的重要環節。傳統開發模式中常見的痛點包括:

  1. 異常處理邏輯分散在各個Controller中
  2. 錯誤響應格式不統一
  3. 敏感異常信息直接暴露給客戶端
  4. 重復編寫相似的異常處理代碼

通過統一異常攔截機制,我們可以:

  • 集中管理異常處理邏輯
  • 規范API錯誤響應格式
  • 自動轉換異常為友好提示
  • 減少重復代碼,提升可維護性

二、核心實現方案

1. 基礎組件

Spring Boot提供了兩個關鍵注解實現全局異常處理:

  • @ControllerAdvice:定義全局控制器增強
  • @ExceptionHandler:聲明具體的異常處理方法

2. 實現步驟

(1)創建自定義異常類
public class BusinessException extends RuntimeException {private final int code;public BusinessException(int code, String message) {super(message);this.code = code;}// getters
}
(2)實現全局異常處理器
@RestControllerAdvice
public class GlobalExceptionHandler {/*** 處理業務異常*/@ExceptionHandler(BusinessException.class)public ResponseResult<Void> handleBusinessException(BusinessException ex) {return ResponseResult.fail(ex.getCode(), ex.getMessage());}/*** 處理空指針異常*/@ExceptionHandler(NullPointerException.class)public ResponseResult<Void> handleNullPointerException(NullPointerException ex) {log.error("空指針異常:", ex);return ResponseResult.fail(500, "系統內部錯誤");}/*** 處理所有未定義異常*/@ExceptionHandler(Exception.class)public ResponseResult<Void> handleGlobalException(Exception ex) {log.error("系統異常:", ex);return ResponseResult.fail(500, "系統繁忙,請稍后再試");}
}
(3)統一響應格式封裝
@Data
@NoArgsConstructor
@AllArgsConstructor
public class ResponseResult<T> {private int code;private String message;private T data;public static <T> ResponseResult<T> success(T data) {return new ResponseResult<>(200, "success", data);}public static <T> ResponseResult<T> fail(int code, String message) {return new ResponseResult<>(code, message, null);}
}

三、高級處理技巧

1. 處理參數校驗異常

配合Validation API自動處理參數校驗錯誤:

@ExceptionHandler(MethodArgumentNotValidException.class)
public ResponseResult<Void> handleValidException(MethodArgumentNotValidException ex) {String message = ex.getBindingResult().getFieldErrors().stream().map(FieldError::getDefaultMessage).collect(Collectors.joining(", "));return ResponseResult.fail(400, message);
}

2. 處理404錯誤

Spring Boot默認的404錯誤需要特殊處理:

@Configuration
public class ErrorConfig implements ErrorController {@RequestMapping("/error")public ResponseResult<Void> handleNoHandlerFound() {return ResponseResult.fail(404, "接口不存在");}
}

3. 區分生產/開發環境

在application.properties中配置:

# 開發環境顯示詳細錯誤
server.error.include-stacktrace=always
# 生產環境隱藏細節
# server.error.include-stacktrace=never

四、方案優勢分析

  1. 統一響應格式:所有異常返回相同結構,方便前端處理
  2. 異常分類處理:可針對不同異常類型定制處理邏輯
  3. 敏感信息過濾:避免暴露堆棧信息等敏感內容
  4. 日志集中記錄:統一記錄異常日志,便于問題排查
  5. 代碼復用率高:減少Controller層的異常處理代碼

五、最佳實踐建議

  1. 定義完善的業務異常體系
  2. 為不同異常類型設計合適的HTTP狀態碼
  3. 生產環境關閉詳細錯誤信息
  4. 配合Swagger等工具生成API文檔
  5. 編寫單元測試驗證異常處理邏輯

完整示例代碼結構:

src/main/java
├── exception
│   ├── BusinessException.java
│   └── GlobalExceptionHandler.java
├── config
│   └── ErrorConfig.java
└── model└── ResponseResult.java

通過實現統一的異常處理機制,可以顯著提升Spring Boot應用的健壯性和可維護性。開發者可以專注于業務邏輯開發,同時保證系統的異常處理符合規范要求。


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/67954.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/67954.shtml
英文地址,請注明出處:http://en.pswp.cn/web/67954.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

使用 Elastic Cloud Hosted 優化長期數據保留:確保政府合規性和效率

作者&#xff1a;來自 Elastic Jennie Davidowitz 在數字時代&#xff0c;州和地方政府越來越多地承擔著管理大量數據的任務&#xff0c;同時確保遵守嚴格的監管要求。這些法規可能因司法管轄區而異&#xff0c;通常要求將數據保留較長時間 —— 有時從一年到七年不等。遵守刑事…

Oracle Primavera P6 最新版 v24.12 更新 2/2

目錄 一. 引言 二. P6 EPPM 更新內容 1. 用戶管理改進 2. 更輕松地標準化用戶設置 3. 摘要欄標簽匯總數據字段 4. 將里程碑和剩余最早開始日期拖到甘特圖上 5. 輕松訪問審計數據 6. 粘貼數據時排除安全代碼 7. 改進了狀態更新卡片視圖中的篩選功能 8. 直接從活動電子…

linux本地部署deepseek-R1模型

國產開源大模型追平甚至超越了CloseAI的o1模型&#xff0c;大國崛起時刻&#xff01;&#xff01;&#xff01; DeepSeek R1 本地部署指南 ??在人工智能技術飛速發展的今天&#xff0c;本地部署AI模型成為越來越多開發者和企業關注的焦點。本文將詳細介紹如何在本地部署DeepS…

C基礎寒假練習(2)

一、輸出3-100以內的完美數&#xff0c;(完美數&#xff1a;因子和(因子不包含自身)數本身 #include <stdio.h>// 函數聲明 int isPerfectNumber(int num);int main() {printf("3-100以內的完美數有:\n");for (int i 3; i < 100; i){if (isPerfectNumber…

有限元分析學習——Anasys Workbanch第一階段筆記梳理

第一階段筆記主要源自于嗶哩嗶哩《ANSYS-workbench 有限元分析應用基礎教程》 張曄 主要內容導圖&#xff1a; 筆記導航如下&#xff1a; Anasys Workbanch第一階段筆記(1)基本信息與結果解讀_有限元分析變形比例-CSDN博客 Anasys Workbanch第一階段筆記(2)網格單元與應力奇…

html基本結構和常見元素

html5文檔基本結構 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><title>文檔標題</title> </head> <body>文檔正文部分 </body> </html> html文檔可分為文檔頭和文檔體…

Cursor如何使用Google Gemini以及碰到的坑

Cursor如何使用Google Gemini以及碰到的坑 Cursor介紹下載安裝Google Gemini介紹Google Gemini 官網申請Google Gemini API網址 配置Cursor使用Google Gemini打開Corsur設置 Cursor介紹 ?Cursor是一款基于人工智能的代碼編輯器&#xff0c;旨在幫助開發者更高效地編寫代碼。?…

【云安全】云原生-K8S-簡介

K8S簡介 Kubernetes&#xff08;簡稱K8S&#xff09;是一種開源的容器編排平臺&#xff0c;用于管理容器化應用的部署、擴展和運維。它由Google于2014年開源并交給CNCF&#xff08;Cloud Native Computing Foundation&#xff09;維護。K8S通過提供自動化、靈活的功能&#xf…

【C++】線程池實現

目錄 一、線程池簡介線程池的核心組件實現步驟 二、C11實現線程池源碼 三、線程池源碼解析1. 成員變量2. 構造函數2.1 線程初始化2.2 工作線程邏輯 3. 任務提交(enqueue方法)3.1 方法簽名3.2 任務封裝3.3 任務入隊 4. 析構函數4.1 停機控制 5. 關鍵技術點解析5.1 完美轉發實現5…

深入理解 C# 與.NET 框架

.NET學習資料 .NET學習資料 .NET學習資料 一、引言 在現代軟件開發領域&#xff0c;C# 與.NET 框架是構建 Windows、Web、移動及云應用的強大工具。C# 作為一種面向對象的編程語言&#xff0c;而.NET 框架則是一個綜合性的開發平臺&#xff0c;它們緊密結合&#xff0c;為開…

雷電等基于VirtualBox的Android模擬器映射串口和測試CSerialPort串口功能

雷電等基于VirtualBox的Android模擬器映射串口和測試CSerialPort串口功能 1. 修改VirtualBox配置文件映射串口 模擬器配置文件vms/leidian0/leidian.vbox。 在UART標簽下增加(修改完成后需要將leidian.vbox修改為只讀) <Port slot"1" enabled"true"…

【Linux系統】SIGCHLD 信號(選學了解)

SIGCHLD 信號 使用wait和waitpid函數可以有效地清理僵尸進程。父進程可以選擇阻塞等待&#xff0c;直到子進程結束&#xff1b;或者采用非阻塞的方式&#xff0c;通過輪詢檢查是否有子進程需要被回收。 然而&#xff0c;無論是選擇阻塞等待還是非阻塞的輪詢方式&#xff0c;父…

【R語言】獲取數據

R語言自帶2種數據存儲格式&#xff1a;*.RData和*.rds。 這兩者的區別是&#xff1a;前者既可以存儲數據&#xff0c;也可以存儲當前工作空間中的所有變量&#xff0c;屬于非標準化存儲&#xff1b;后者僅用于存儲單個R對象&#xff0c;且存儲時可以創建標準化檔案&#xff0c…

Vim的基礎命令

移動光標 H(左) J(上) K(下) L(右) $ 表示移動到光標所在行的行尾&#xff0c; ^ 表示移動到光標所在行的行首的第一個非空白字符。 0 表示移動到光標所在行的行首。 W 光標向前跳轉一個單詞 w光標向前跳轉一個單詞 B光標向后跳轉一個單詞 b光標向后跳轉一個單詞 G 移動光標到…

11. 9 構建生產級聊天對話記憶系統:從架構設計到性能優化的全鏈路指南

構建生產級聊天對話記憶系統:從架構設計到性能優化的全鏈路指南 關鍵詞: 聊天對話記憶系統、多用戶會話管理、LangChain生產部署、Redis記憶存儲、高并發對話系統 一、服務級聊天記憶系統核心需求 多用戶隔離:支持同時處理數千個獨立對話持久化存儲:對話歷史不因服務重啟丟…

Block Blaster Online:免費解謎游戲的樂趣

Block Blaster Online 是一款免費的在線解謎游戲&#xff0c;它將挑戰你的思維和反應能力&#xff01;在這里&#xff0c;你可以匹配五彩繽紛的方塊&#xff0c;創造出令人驚嘆的組合&#xff0c;享受無盡的解謎樂趣。無需安裝&#xff0c;點擊即可開始&#xff0c;加入全球數百…

Guided Decoding (借助FSM,有限狀態自動機)

VLLM對結構化輸出的支持&#xff1a; vllm/docs/source/features/structured_outputs.md at main vllm-project/vllm GitHub VLLM對tool call的支持&#xff1a; vllm/docs/source/features/tool_calling.md at main vllm-project/vllm GitHub 以上指定輸出格式&#xf…

IFeatureWorkspace.CreateFeatureClass(),報錯對COM組件的調用返回了錯誤 HRESULT E_FAIL

1、問題描述&#xff1a;在AE開發中&#xff0c;新增一個空的shpfile文件的時候&#xff0c;報錯&#xff0c;如下圖&#xff1a; 2、原因分析&#xff1a;產生此問題的原因是未設置默認字段的默認參數&#xff0c;特別是未設置IGeometryDef 參數。 3、解決方案&#xff1a;在…

算法題(48):反轉鏈表

審題&#xff1a; 需要我們將鏈表反轉并返回頭結點地址 思路&#xff1a; 一般在面試中&#xff0c;涉及鏈表的題會主要考察鏈表的指向改變&#xff0c;所以一般不會允許我們改變節點val值。 這里是單向鏈表&#xff0c;如果要把指向反過來則需要同時知道前中后三個節點&#x…

內存的介紹

1、程序運行為什么需要內存 1.1、計算機程序運行的目的 (1)程序的目的是為了去運行&#xff0c;程序運行是為了得到一定的結果。 (2)計算機程序 代碼 數據。計算機程序運行完得到一個結果&#xff0c;就是說 代碼 數據 (經過運行后) 結果。 (3)從宏觀上來理解&#xff…