自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Spring 6/Spring Boot 3新特性:優(yōu)雅的業(yè)務(wù)異常處理

開發(fā) 前端
當(dāng)你使用Spring Boot(Spring MVC)進(jìn)行RESTful API開發(fā)的時(shí)候,你會(huì)發(fā)現(xiàn)HTTP的狀態(tài)碼很多時(shí)候不能足夠有效的傳遞錯(cuò)誤的信息。

當(dāng)你使用Spring Boot(Spring MVC)進(jìn)行RESTful API開發(fā)的時(shí)候,你會(huì)發(fā)現(xiàn)HTTP的狀態(tài)碼很多時(shí)候不能足夠有效的傳遞錯(cuò)誤的信息。

HTTP里有一個(gè)RFC 7807規(guī)范:https://www.rfc-editor.org/rfc/rfc7807。這個(gè)規(guī)范里定義了HTTP API的“問題細(xì)節(jié)”(Problem Details)內(nèi)容。

該規(guī)范定義了一個(gè)“問題細(xì)節(jié)”(Problem Details),用它來攜帶HTTP錯(cuò)誤返回信息,避免自定義新的錯(cuò)誤返回格式。我們通常情況下是自己定義錯(cuò)誤返回格式的。

Spring 6.0為我們提供了一個(gè)org.springframework.http.ProblemDetail 來實(shí)現(xiàn)該規(guī)范。

RFC 7807是一個(gè)很簡單的規(guī)范。它定義了一個(gè)JSON格式,并關(guān)聯(lián)了一個(gè)媒體類型(media type),這個(gè)JSON格式包含了五個(gè)可選成員來描述問題細(xì)節(jié):

type:一個(gè)URI引用,用來識(shí)別問題的類型。這個(gè)URI的路徑內(nèi)容應(yīng)該用來顯示人類可讀的信息來描述類型;

title:人類可讀的問題類型描述;相同類型的問題,應(yīng)該總是相同的描述;

status:HTTP狀態(tài)碼,將它包含在問題細(xì)節(jié)里是一種方便的方式;

detail:人類可讀的問題實(shí)例描述,解釋為什么當(dāng)前的問題發(fā)生在這個(gè)特定的場(chǎng)景下;

instance:一個(gè)URI引用,用來識(shí)別問題實(shí)例。這個(gè)URI的內(nèi)容應(yīng)該用來描述問題實(shí)例,但不是必須的。

我們首先建立一個(gè)演示項(xiàng)目:

1、通常的業(yè)務(wù)異常處理方法

定義一個(gè)業(yè)務(wù)異常類。異常含義為:當(dāng)Person找不到的時(shí)候拋出的業(yè)務(wù)異常。

public class PersonNotFoundException  extends RuntimeException {
@Getter
private final HttpStatus status;

public PersonNotFoundException(String message, HttpStatus status){
super(message);
this.status = status;
}
}

注冊(cè)這個(gè)業(yè)務(wù)異常到全局異常處理。

通過在@RestControllerAdvice 中定義全局的切面處理。

通過@ExceptionHandler 來處理指定異常的處理方式。

這里返回的格式就是我們自定義的ErrorMsg格式。我們通過自定義這個(gè)ErroMsg完成和接口使用者協(xié)議,完成對(duì)業(yè)務(wù)異常的處理。

@RestControllerAdvice
public class GlobalExceptionHandler {
@ExceptionHandler(PersonNotFoundException.class)
public ResponseEntity<ErrorMsg> personNotFoundHandler(PersonNotFoundException e) {
ErrorMsg msg = new ErrorMsg("0000", e.getMessage());
return new ResponseEntity<>(msg, e.getStatus());
}
}

需自定義的錯(cuò)誤返回

@Data
@AllArgsConstructor
@NoArgsConstructor
public class ErrorMsg {
private String code;
private String msg;
}

測(cè)試控制器

@RestController
public class PersonController {

@GetMapping("/getPerson")
public String getPerson(){
throw new PersonNotFoundException("查找的人不存在", HttpStatus.NOT_FOUND);
}
}

啟動(dòng)程序,訪問:http://localhost:8080/getPerson

2、基于“問題細(xì)節(jié)”的業(yè)務(wù)異常處理

基于我們常規(guī)的異常處理,其實(shí)已經(jīng)能滿足我們的業(yè)務(wù)需求,使用RFC 7807規(guī)范,我們可以免去自定義的異常錯(cuò)誤格式(ErrorMsg ),使用Spring 6.0給我們提供的ProblemDetail ,這樣我們以后再無需自己自定義異常返回格式,且在不同的項(xiàng)目之間有了標(biāo)準(zhǔn),從而客戶端在使用的時(shí)候有了可預(yù)測(cè)性。

Spring 6.0的做法也很簡單,我們只需要將我們自定返回的ErrorMsg 修改成ProblemDetail 即可。我們看一下示例代碼:

@RestControllerAdvice
public class GlobalExceptionHandler {

@ExceptionHandler(PersonNotFoundException.class)
public ProblemDetail personNotFoundHandler(PersonNotFoundException e) {
ProblemDetail problemDetail = ProblemDetail.forStatus(HttpStatus.NOT_FOUND);
problemDetail.setType(URI.create("https://www.toutiao.com/c/user/token/MS4wLjABAAAAJxW0bvHKNNwIpcsocIDAjNHHNXg2yaj1upViHO2JVNw/"));
problemDetail.setTitle("Person Not Found");
problemDetail.setDetail(String.format("錯(cuò)誤信息:‘%s’", e.getMessage()));
return problemDetail;
}
}

值得說的是ProblemDetail 還支持設(shè)置一個(gè)Map的properties:

private Map<String, Object> properties;

這樣也為我們的定制擴(kuò)展提供了更大的空間。

啟動(dòng),訪問:http://localhost:8080/getPerson,其實(shí)的錯(cuò)誤返回符合RFC 7807規(guī)范。

注意查看返回的頭信息,我們看到了,返回?cái)?shù)據(jù)的媒體類型為:application/problem+json:

感謝支持我的書:《從企業(yè)級(jí)開發(fā)到云原生微服務(wù):Spring Boot實(shí)戰(zhàn)》

參考資料:https://docs.spring.io/spring-framework/docs/6.0.0-RC2/javadoc-api/org/springframework/http/ProblemDetail.html

文章出自:??愛科學(xué)的衛(wèi)斯理??,如有轉(zhuǎn)載本文請(qǐng)聯(lián)系愛科學(xué)的衛(wèi)斯理今日頭條號(hào)。

責(zé)任編輯:武曉燕 來源: 愛科學(xué)的衛(wèi)斯理
相關(guān)推薦

2021-04-20 10:50:38

Spring Boot代碼Java

2024-08-02 09:15:22

Spring捕捉格式

2025-02-07 09:11:04

JSON對(duì)象策略

2025-04-16 10:03:40

開發(fā)Spring應(yīng)用程序

2022-04-08 16:27:48

SpringBoot異常處理

2021-09-15 09:02:20

Spring 6Spring BootJava

2021-09-03 06:46:34

Spring 6pring Boot 項(xiàng)目

2020-03-16 17:20:02

異常處理Spring Boot

2024-10-11 11:32:22

Spring6RSocket服務(wù)

2024-09-27 12:27:31

2024-12-18 16:19:51

2018-06-06 14:30:38

Spring BootApplication事件

2023-09-24 13:55:42

Spring應(yīng)用程序

2009-06-18 15:40:07

Spring Batc

2009-06-24 09:22:04

Spring2.5新特

2025-04-27 04:00:00

錯(cuò)誤頁Spring底層

2025-03-11 00:55:00

Spring停機(jī)安全

2025-02-13 00:34:22

Spring對(duì)象系統(tǒng)

2018-05-30 15:10:24

Spring BootList類型

2024-05-31 14:06:55

SpringCDSGraalVM
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)