1. 程式人生 > >Spring Boot HTTP over JSON 的錯誤碼異常處理

Spring Boot HTTP over JSON 的錯誤碼異常處理

作者:泥瓦匠

本文提綱
一、異常統一處理的使用場景
二、執行 springboot-validation-over-json 工程
三、springboot-validation-over-json 工程程式碼詳解

一、異常統一處理的使用場景

在前後端分離開發中,經常用 HTTP over JSON 作為服務進行前後端聯調對接。這裡簡單介紹下為啥前後端分離開發?我想到如下:

1.低耦合,責權分離,模組化。前後端之間利用輕量級協議對接耦合。
2.便於敏捷開發:後端給出 api 文件 -> 前端根據文件,mock出資料開發 ;同時,後端實現業務邏輯。
3.微服務尤其適用

這時候 HTTP over JSON 形式中很多涉及到返回碼,錯誤碼相關的處理。比如xxx引數不完整,許可權不足,使用者不存在等。

怎麼統一處理認為是異常的場景呢?
利用的是 Spring 4.x 提供的 RestControllerAdvice。這裡做下說明,也可以根據 ControllerAdvice 去實現。這裡案例是 HTTP over JSON 模式,所以直接利用
RestControllerAdvice ,控制層通知器,這裡用於統一攔截異常,進行響應處理。工作模式,如圖:

二、執行 springboot-validation-over-json 工程

執行環境:JDK 7 或 8,Maven 3.0+
技術棧:SpringBoot 1.5+(內涵 Spring 4.x)

1.git clone 下載工程 springboot-learning-example


專案地址見 GitHub – https://github.com/JeffLi1993/springboot-learning-example:

git clone [email protected]:JeffLi1993/springboot-learning-example.git

然後,Maven 編譯安裝這個工程:

cd springboot-learning-example
mvn clean install

2.執行 springboot-validation-over-json 工程
右鍵執行 springboot-validation-over-json 工程 Application 應用啟動類的 main 函式。預設埠 8080

3.訪問案例
a. 引數不完整案例:
訪問瀏覽器開啟下面連結,可得到以下 JSON 返回
http://localhost:8080/api/city?cityName=

{
    "code": "000001",
    "message": "params no complete",
    "result": null
}

b. 成功案例:
訪問瀏覽器開啟下面連結,可得到以下 JSON 返回
http://localhost:8080/api/city?cityName=%E6%B8%A9%E5%B2%AD%E5%B8%82

{
    "code": "0",
    "message": "success",
    "result": {
        "id": 1,
        "provinceId": 2,
        "cityName": "溫嶺",
        "description": "是我的故鄉"
    }
}

三、springboot-validation-over-json 工程程式碼詳解

程式碼詳解提綱:
a.控制層通知器
b.響應碼設計

首先,工程程式碼目錄如下:

├── pom.xml
└── src
    └── main
        └── java
            └── org
                └── spring
                    └── springboot
                        ├── Application.java
                        ├── constant
                        │   └── CityErrorInfoEnum.java
                        ├── result
                        │   ├── ErrorInfoInterface.java
                        │   ├── GlobalErrorInfoEnum.java
                        │   ├── GlobalErrorInfoException.java
                        │   ├── GlobalErrorInfoHandler.java
                        │   └── ResultBody.java
                        └── web
                            ├── City.java
                            └── ErrorJsonController.java

a.控制層通知器
GlobalErrorInfoHandler.java 程式碼如下:

@RestControllerAdvice
public class GlobalErrorInfoHandler {

@ExceptionHandler(value = GlobalErrorInfoException.class)
public ResultBody errorHandlerOverJson(HttpServletRequest request,
GlobalErrorInfoException exception) {
    ErrorInfoInterface errorInfo = exception.getErrorInfo();
    ResultBody result = new ResultBody(errorInfo);
    return result;
}
}

@ExceptionHandler 註解,標記了使用 errorHandlerOverJson() 方法來處理 GlobalErrorInfoException 異常。
@RestControllerAdvice 是 @ControllerAdvice 和 @ResponseBody 的語義結合。是控制器增強,直接返回物件。這裡用於統一攔截異常,然後返回錯誤碼物件體。
@ResponseBody 作用: 該註解用於將 Controller 的方法返回的物件,通過適當的 HttpMessageConverter 轉換為指定格式後,寫入到 Response 物件的 body 資料區。

b.響應碼設計
簡單講講,這裡定義了一個錯誤碼介面,全域性錯誤碼列舉和各個業務錯誤碼列舉去實現介面,並用列舉值枚舉出錯誤碼及錯誤碼訊息列表。如圖:

四、小結

如果實戰中,大家遇到什麼,或者建議《Spring boot 那些事》還需要一起交流的。請點選留言。

推薦書《騰訊傳》,其中幾章寫的很不錯。

歡迎掃一掃我的公眾號關注 — 及時得到部落格訂閱哦!
— http://www.bysocket.com/ —
— https://github.com/JeffLi1993 —