摘要: 原創出處:www.bysocket.com 泥瓦匠BYSocket 希望轉載,保留摘要,謝謝!
“年輕人不要怕表現,要敢於出來表現,但還是那句話,要有正確的度,你的表現是分析問題和解決問題的能力。”
– 《你憑什么做好互聯網》
本文提綱
一、異常統一處理的使用場景
二、運行 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:
1
|
git clone git@github.com:JeffLi1993
/springboot-learning-example
.git
|
然后,Maven 編譯安裝這個工程:
1
2
|
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=
1
2
3
4
5
|
{
"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
1
2
3
4
5
6
7
8
9
10
|
{
"code"
:
"0"
,
"message"
:
"success"
,
"result"
: {
"id"
: 1,
"provinceId"
: 2,
"cityName"
:
"溫嶺"
,
"description"
:
"是我的故鄉"
}
}
|
三、springboot-validation-over-json 工程代碼詳解
代碼詳解提綱:
a.控制層通知器
b.響應碼設計
同樣,代碼共享在我的 GitHub 上:
https://github.com/JeffLi1993/springboot-learning-example/tree/master/springboot-validation-over-json
首先,工程代碼目錄如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
├── 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 代碼如下:
1
2
3
4
5
6
7
8
9
10
11
|
@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 —