Springboot之自定義全局異常處理的實現(xiàn)
前言:
在實際的應用開發(fā)中,很多時候往往因為一些不可控的因素導致程序出現(xiàn)一些錯誤,這個時候就要及時把異常信息反饋給客戶端,便于客戶端能夠及時地進行處理,而針對代碼導致的異常,我們一般有兩種處理方式,一種是throws直接拋出,一種是使用try..catch捕獲,一般的話,如果邏輯的異常,需要知道異常信息,我們往往選擇將異常拋出,如果只是要保證程序在出錯的情況下 依然可以繼續(xù)運行,則使用try..catch來捕獲。
但是try..catch會導致代碼量的增加,讓后期我們的代碼變得臃腫且難以維護。當然,springboot作為一個如此優(yōu)秀的框架,肯定不會坐視不管的,通過springboot自帶的注解,我們可以方便的自定義我們的全局異常處理器,并且以json格式返回給我們的客戶端。
代碼實戰(zhàn):
捕獲全局異常:
首先呢,我們新建我們負責全局異常捕捉處理的類:MyControllerAdvice,代碼如下:
@ControllerAdvice public class MyControllerAdvice { @ResponseBody @ExceptionHandler(value = Exception.class) public Map<String,Object> exceptionHandler(Exception ex){ Map<String,Object> map = new HashMap<String,Object>(); map.put("code",100); map.put("msg",ex.getMessage()); //這里可以加上我們其他的異常處理代碼,比如日志記錄,,, return map; } }
注解說明:
@ControllerAdvice 通過AOP的方式配合@ExceptionHandler()注解捕獲在Controller層面發(fā)生的異常。如果需要掃描自定路徑下的Controller,添加basePackages屬性
@ControllerAdvice(basePackages ="com.example.demo.controller")
@RestControllerAdvice : 和@ControllerAdvice作用相同,可以理解為 @ResponseBody+@ControllerAdvice 的組合使用。
@ExceptionHandler():該注解作用主要在于聲明一個或多個類型的異常,當符合條件的Controller拋出這些異常之后將會對這些異常進行捕獲,然后按照其標注的方法的邏輯進行處理,從而改變返回的視圖信息。
測試:
@RestController public class UserController { @GetMapping("/test") public String test(){ int num = 1/0; return "Hello World"; } }
結(jié)果:
{"msg":"/ by zero","code":100}
捕獲自定義異常:
自定義我們的異常信息類MyException 并繼承RuntimeException:
public class MyException extends RuntimeException { private String errorCode; private String errorMsg; public MyException(String errorCode, String errorMsg) { this.errorCode = errorCode; this.errorMsg = errorMsg; } public String getErrorCode() { return errorCode; } public void setErrorCode(String errorCode) { this.errorCode = errorCode; } public String getErrorMsg() { return errorMsg; } public void setErrorMsg(String errorMsg) { this.errorMsg = errorMsg; } }
修改我們的MyControllerAdvice,將MyException添加進去:
@ResponseBody @ExceptionHandler(value = MyException.class) public Map<String,Object> myExceptionHandler(MyException mex){ Map<String,Object> map = new HashMap<String,Object>(); map.put("code",mex.getErrorCode()); map.put("msg",mex.getErrorMsg()); //其他業(yè)務代碼... return map; }
測試:
@GetMapping("/test1") public String test1(){ String name = null; if(name == null){ throw new MyException("101","用戶名為空"); } return "Hello World"; }
輸出:
{"msg":"用戶名為空","code":"101"}
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
關于Spring MVC同名參數(shù)綁定問題的解決方法
Spring MVC中的參數(shù)綁定還是蠻重要的,最近在使用中遇到了同名參數(shù)綁定的問題,想著總結(jié)分享出來,下面這篇文章主要給大家介紹了關于Spring MVC同名參數(shù)綁定問題的解決方法,需要的朋友可以參考借鑒,下面來一起看看吧。2017-08-08淺談Android開發(fā)中項目的文件結(jié)構(gòu)及規(guī)范化部署建議
這篇文章主要介紹了Android開發(fā)中項目的文件結(jié)構(gòu)及規(guī)范化部署建議,組織好代碼文件的結(jié)構(gòu)有利于維護團隊合作的效率,需要的朋友可以參考下2016-03-03Elasticsearch中store field與non-store field的區(qū)別說明
這篇文章主要介紹了Elasticsearch中store field與non-store field的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07Spring Boot熱加載jar實現(xiàn)動態(tài)插件的思路
本文主要介紹在 Spring Boot 工程中熱加載 jar 包并注冊成為 Bean 對象的一種實現(xiàn)思路,在動態(tài)擴展功能的同時支持在插件中注入主程序的 Bean 實現(xiàn)功能更強大的插件2021-10-10Spring容器刷新obtainFreshBeanFactory示例詳解
這篇文章主要為大家介紹了Spring容器刷新obtainFreshBeanFactory示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03