SpringBoot中默認(rèn)異常處理機(jī)制的實(shí)現(xiàn)
在 Spring Boot 中,為了簡(jiǎn)化 Web 應(yīng)用的異常處理流程,它提供了一套默認(rèn)的全局異常處理機(jī)制,其中最核心的就是 /error 接口。這個(gè)接口是 Spring Boot 提供的一個(gè)內(nèi)置錯(cuò)誤頁(yè)面控制器(BasicErrorController),用于統(tǒng)一返回錯(cuò)誤信息。
?? 一句話總結(jié):
? Spring Boot 默認(rèn)使用 BasicErrorController 來(lái)處理所有未被捕獲的異常,并通過(guò) /error 接口返回結(jié)構(gòu)化的錯(cuò)誤響應(yīng)或跳轉(zhuǎn)到錯(cuò)誤頁(yè)面(如 HTML 頁(yè)面)。
?? 一、默認(rèn)行為概覽
| 請(qǐng)求類(lèi)型 | 返回內(nèi)容 |
|---|---|
| 瀏覽器請(qǐng)求(HTML) | 跳轉(zhuǎn)到 /error 頁(yè)面(如 error.html) |
| API 請(qǐng)求(JSON/REST) | 返回 JSON 格式的錯(cuò)誤信息 |
例如:
- 訪問(wèn)一個(gè)不存在的路徑:
GET /not-found - 控制器拋出未處理的異常 都會(huì)被 Spring Boot 的
/error端點(diǎn)捕獲并處理。
??? 二、核心組件解析
1.BasicErrorController
這是 Spring Boot 默認(rèn)提供的錯(cuò)誤處理器,負(fù)責(zé)處理 /error 請(qǐng)求。
@Controller
@RequestMapping("${server.error.path:${spring.mvc.async.request-timeout}}")
public class BasicErrorController extends AbstractErrorController {
...
}- 默認(rèn)路徑為
/error(可通過(guò)server.error.path配置修改) - 支持兩種響應(yīng)格式:
text/html:返回 HTML 錯(cuò)誤頁(yè)面(如error.html)- 其他格式(如 JSON):返回結(jié)構(gòu)化錯(cuò)誤信息
2.ErrorAttributes接口
該接口定義了錯(cuò)誤信息的內(nèi)容來(lái)源,包括:
- 異常對(duì)象
- HTTP 狀態(tài)碼
- 請(qǐng)求 URL
- 時(shí)間戳等
默認(rèn)實(shí)現(xiàn)是 DefaultErrorAttributes,你也可以自定義。
3.ErrorViewResolver接口
用于解析 HTML 錯(cuò)誤頁(yè)面。例如:
/templates/error/404.html/templates/error/5xx.html/templates/error.html
Spring Boot 會(huì)根據(jù)狀態(tài)碼優(yōu)先匹配具體頁(yè)面。
?? 三、默認(rèn)返回的 JSON 錯(cuò)誤結(jié)構(gòu)
當(dāng)你訪問(wèn)一個(gè) REST 接口時(shí),如果發(fā)生異常且沒(méi)有被 @ExceptionHandler 或 @ControllerAdvice 捕獲,Spring Boot 會(huì)返回如下格式的 JSON 響應(yīng):
{
"timestamp": "2025-07-12T10:45:00.000+00:00",
"status": 404,
"error": "Not Found",
"path": "/not-found"
}字段說(shuō)明:
| 字段名 | 含義 |
|---|---|
| timestamp | 錯(cuò)誤發(fā)生時(shí)間 |
| status | HTTP 狀態(tài)碼 |
| error | 錯(cuò)誤描述 |
| exception | 異常類(lèi)名(僅當(dāng) spring.boot.debug=true 時(shí)顯示) |
| message | 異常消息(可選) |
| path | 出錯(cuò)的請(qǐng)求路徑 |
?? 四、如何自定義錯(cuò)誤處理?
雖然 Spring Boot 提供了默認(rèn)的錯(cuò)誤處理機(jī)制,但在實(shí)際項(xiàng)目中我們通常需要進(jìn)行定制:
1.方式一:自定義ErrorAttributes
你可以實(shí)現(xiàn) ErrorAttributes 接口來(lái)自定義錯(cuò)誤信息內(nèi)容:
@Component
public class CustomErrorAttributes extends DefaultErrorAttributes {
@Override
public Map<String, Object> getErrorAttributes(WebRequest webRequest, ErrorAttributeOptions options) {
Map<String, Object> errorMap = super.getErrorAttributes(webRequest, options);
errorMap.put("customInfo", "This is a custom error info.");
return errorMap;
}
}2.方式二:繼承BasicErrorController自定義控制器
@RestController
@RequestMapping("${server.error.path:/error}")
public class CustomErrorController extends BasicErrorController {
public CustomErrorController(ErrorAttributes errorAttributes) {
super(errorAttributes, new ErrorProperties());
}
@Override
public ResponseEntity<Map<String, Object>> error(HttpServletRequest request) {
Map<String, Object> body = getErrorAttributes(new ServletWebRequest(request), true);
return new ResponseEntity<>(body, HttpStatus.INTERNAL_SERVER_ERROR);
}
}3.方式三:創(chuàng)建自定義錯(cuò)誤頁(yè)面(HTML)
將 HTML 頁(yè)面放在以下位置之一即可:
src/main/resources/templates/error/404.htmlsrc/main/resources/static/error/500.htmlsrc/main/resources/public/error.html
Spring Boot 會(huì)根據(jù) HTTP 狀態(tài)碼自動(dòng)選擇對(duì)應(yīng)的頁(yè)面。
4.方式四:使用@ControllerAdvice全局處理異常
@RestControllerAdvice
public class GlobalExceptionHandler {
@ExceptionHandler(Exception.class)
public ResponseEntity<Map<String, Object>> handleException(Exception ex, HttpServletRequest request) {
Map<String, Object> errorBody = new HashMap<>();
errorBody.put("error", ex.getMessage());
errorBody.put("path", request.getRequestURI());
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(errorBody);
}
}這種方式比默認(rèn)機(jī)制更靈活,適用于大型項(xiàng)目。
?? 五、配置相關(guān)屬性(application.yml)
你可以在 application.yml 或 application.properties 中配置一些與錯(cuò)誤相關(guān)的參數(shù):
spring:
mvc:
async:
request-timeout: 0 # 禁用超時(shí)控制
server:
error:
path: /my-error # 自定義錯(cuò)誤路徑
whitelabel:
enabled: false # 關(guān)閉默認(rèn)白標(biāo)錯(cuò)誤頁(yè)? 六、總結(jié)
| 項(xiàng)目 | 內(nèi)容 |
|---|---|
| 默認(rèn)錯(cuò)誤端點(diǎn) | /error |
| 默認(rèn)控制器 | BasicErrorController |
| 默認(rèn)錯(cuò)誤信息 | DefaultErrorAttributes |
| 默認(rèn)視圖支持 | 支持 HTML 錯(cuò)誤頁(yè)面(按狀態(tài)碼命名) |
| JSON 輸出格式 | 包含 timestamp, status, error, path 等字段 |
| 可擴(kuò)展性 | 支持自定義 ErrorAttributes、ErrorController、HTML 頁(yè)面、@ControllerAdvice |
到此這篇關(guān)于SpringBoot中默認(rèn)異常處理機(jī)制的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)SpringBoot 默認(rèn)異常處理機(jī)制內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring中BeanFactoryPostProcessors是如何執(zhí)行的
BeanFactoryPostProcessor是Spring容器提供的一個(gè)擴(kuò)展機(jī)制,它允許開(kāi)發(fā)者在Bean的實(shí)例化和初始化之前對(duì)BeanDefinition進(jìn)行修改和處理,這篇文章主要介紹了你知道Spring中BeanFactoryPostProcessors是如何執(zhí)行的嗎,需要的朋友可以參考下2023-11-11
maven繼承父工程統(tǒng)一版本號(hào)的實(shí)現(xiàn)
這篇文章主要介紹了maven繼承父工程統(tǒng)一版本號(hào)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
基于springboot+vue實(shí)現(xiàn)垃圾分類(lèi)管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了基于springboot+vue實(shí)現(xiàn)垃圾分類(lèi)管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07
Java實(shí)現(xiàn)發(fā)送HTML內(nèi)容并帶附件的電子郵件
這篇文章主要為大家詳細(xì)介紹了如何使用Java實(shí)現(xiàn)發(fā)送HTML內(nèi)容并帶附件的電子郵件,文中的示例代碼講解詳細(xì),有需要的小伙伴可以參考一下2025-01-01
Spring Boot項(xiàng)目中定制攔截器的方法詳解
這篇文章主要介紹了Spring Boot項(xiàng)目中定制攔截器的方法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10
MybatisPlus特殊查詢(xún)的實(shí)現(xiàn)介紹
這篇文章主要介紹了MybatisPlus查詢(xún)投影、聚合查詢(xún)、分組查詢(xún)、等值查詢(xún)、范圍查詢(xún)、模糊查詢(xún)、排序查詢(xún),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2022-10-10
使用Backoff策略提高HttpClient連接管理的效率
這篇文章主要為大家介紹了Backoff策略提高HttpClient連接管理的效率使用解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10

