重複功能我來寫。在 SpringBoot
項目裏都有全局異常處理以及返回包裝等,返回前端是帶上succ
、code
、msg
、data
等字段。單個項目狀況下很好解決,當微服務模塊多的狀況下,不少狀況開發都是複製原有代碼進行構建另一個項目的,致使這些功能升級須要修改多個服務,在這個基礎上,咱們封裝了一個組件 unified-dispose-springboot-starter
裏面包含了一些基礎的異常處理以及返回包裝功能。前端
添加依賴ps: 實際version版本請使用最新版最新版本: ![Maven Central](https://search.maven.org/search?q=g:com.purgeteam%20AND%20a:unified-dispose-springboot-starter)git
點擊查看最新新版本github
<dependency>
<groupId>com.purgeteam</groupId>
<artifactId>unified-dispose-springboot-starter</artifactId>
<version>0.1.1.RELEASE</version>
</dependency>複製代碼
啓動類添加 @EnableGlobalDispose
註解開啓如下功能。web
@EnableGlobalDispose
@SpringBootApplication
public class GlobalDisposeSpringBootApplication {
public static void main(String[] args) {
SpringApplication.run(GlobalDisposeSpringBootApplication.class, args);
}
}複製代碼
在項目中常常出現系統異常的狀況,好比NullPointerException
等等。若是默認未處理的狀況下,springboot
會響應默認的錯誤提示,這樣對用戶體驗不是友好,系統層面的錯誤,用戶不能感知到,即便爲500
的錯誤,能夠給用戶提示一個相似服務器開小差
的友好提示等。spring
模塊裏以及包含了一些基本的異常處理方式(及不須要作任何代碼編寫已經具備基本異常處理),以及一些常見的異常code,用戶只須要關心業務異常處理便可,直接經過 throw new 異常
的方式拋出便可。springboot
# 通用500異常
Exception 類捕獲 500 異常處理
# Feign 異常
FeignException 類捕獲
ClientException 類捕獲
# 業務自定義
BusinessException 類捕獲 業務通用自定義異常
# 參數校驗異常
HttpMessageNotReadableException 參數錯誤異常
BindException 參數錯誤異常複製代碼
throw new BusinessException(BusinessErrorCode.BUSINESS_ERROR);
// 或者
throw new BusinessException("CLOUD800","沒有多餘的庫存");複製代碼
一般不建議直接拋出通用的BusinessException異常,應當在對應的模塊裏添加對應的領域的異常處理類以及對應的枚舉錯誤類型。服務器
如會員模塊:建立UserException
異常類、UserErrorCode
枚舉、以及UserExceptionHandler
統一攔截類。微信
UserException:app
@Data
public class UserException extends RuntimeException {
private String code;
private boolean isShowMsg = true;
/**
* 使用枚舉傳參
*
* @param errorCode 異常枚舉
*/
public UserException(UserErrorCode errorCode) {
super(errorCode.getMessage());
this.setCode(errorCode.getCode());
}
}複製代碼
UserErrorCode:maven
@Getter
public enum UserErrorCode {
/**
* 權限異常
*/
NOT_PERMISSIONS("CLOUD401","您沒有操做權限"),
;
private String code;
private String message;
CommonErrorCode(String code, String message) {
this.code = code;
this.message = message;
}
}複製代碼
UserExceptionHandler:
@Slf4j
@RestControllerAdvice
public class UserExceptionHandler {
/**
* UserException 類捕獲
*/
@ExceptionHandler(value = UserException.class)
public Result handler(UserException e) {
log.error(e.getMessage(), e);
return Result.ofFail(e.getCode(), e.getMessage());
}
}複製代碼
最後業務使用以下:
// 判斷是否有權限拋出異常
throw new UserException(UserErrorCode.NOT_PERMISSIONS);複製代碼
上述方式,拋出異常後會被模塊處理。前臺返回以下:
{
"succ": false, // 是否成功
"ts": 1566467628851, // 時間戳
"data": null, // 數據
"code": "CLOUD800", // 錯誤類型
"msg": "業務異常", // 錯誤描述
"fail": true
}複製代碼
在REST風格的開發中,避免一般會告知前臺返回是否成功以及狀態碼等信息。這裏咱們一般返回的時候作一次util
的包裝處理工做,如:Result
相似的類,裏面包含succ
、code
、msg
、data
等字段。
接口調用處理相似以下:
@GetMapping("hello")
public Result list(){
return Result.ofSuccess("hello");
}複製代碼
結果:
{
"succ": ture, // 是否成功
"ts": 1566467628851, // 時間戳
"data": "hello", // 數據
"code": null, // 錯誤類型
"msg": null, // 錯誤描述
"fail": true
}複製代碼
默認狀況全部的 web controller
都會被封裝爲一下返回格式。
接口:
@GetMapping("test")
public String test(){
return "test";
}複製代碼
返回
{
"succ": true, // 是否成功
"ts": 1566386951005, // 時間戳
"data": "test", // 數據
"code": null, // 錯誤類型
"msg": null, // 錯誤描述
"fail": false
}複製代碼
@IgnorReponseAdvice
容許範圍爲:類 + 方法,標識在類上這個類下的說有方法的返回都將忽略返回封裝。
接口:
@IgnorReponseAdvice // 忽略數據包裝 可添加到類、方法上
@GetMapping("test")
public String test(){
return "test";
}複製代碼
返回 test
項目裏不少重複的code,咱們能夠經過必定的方式去簡化,以達到必定目的減小開發量。PurgeTeam 具備一些優秀的開源組件,減小平常的開發量。
示例代碼地址:unified-dispose-springboot
做者GitHub:
Purgeyao 歡迎關注qq交流羣:
812321371
微信交流羣:MercyYao
微信公衆號: