SpringBoot開發技巧啟動時配置校驗實現示例
概述
在項目開發過程中,某個功能需要依賴在配置文件中配置的參數。這時候就可能出現下面這種現象問題:
有時候經常出現項目啟動瞭,等到使用某個功能組件的時候出現異常,提示參數未配置或者bean註入失敗。
有沒有一種方法在項目啟動時就對參數進行校驗而不是在實際使用的時候再拋出提示呢?
答案就是使用Spring提供的Java Validation功能,簡單實用。
增加啟動校驗
隻需要在我們創建的配置Properties類增加Validation相關配置即可
@Validated @Data @ConfigurationProperties(prefix = "app") @Component public class AppConfigProperties { @NotEmpty(message = "配置文件配置必須要配置[app.id]屬性") private String id; }
上面的配置就會校驗我們在 application.yml
中有沒有配置 app.id
參數。如果在配置文件中沒有該配置,項目啟動就會失敗,並拋出校驗異常。
在使用配置文件校驗時,必須使用@configurationproperties註解,@value不支持該註解。
在需要使用app.id的時候註入配置類即可:
@Autowired private AppConfigProperties appConfigProperties;
這樣就可以實現我們想要的效果,如下圖:
效果
校驗類型
校驗規則 | 規則說明 |
---|---|
@Null | 限制隻能為null |
@NotNull | 限制必須不為null |
@AssertFalse | 限制必須為false |
@AssertTrue | 限制必須為true |
@DecimalMax(value) | 限制必須為一個不大於指定值的數字 |
@DecimalMin(value) | 限制必須為一個不小於指定值的數字 |
@Digits(integer,fraction) | 限制必須為一個小數,且整數部分的位數不能超過integer,小數部分的位數不能超過fraction |
@Future | 限制必須是一個將來的日期 |
@Max(value) | 限制必須為一個不大於指定值的數字 |
@Min(value) | 限制必須為一個不小於指定值的數字 |
@Past | 驗證註解的元素值(日期類型)比當前時間早 |
@Pattern(value) | 限制必須符合指定的正則表達式 |
@Size(max,min) | 限制字符長度必須在min到max之間 |
@NotEmpty | 驗證註解的元素值不為null且不為空(字符串長度不為0、集合大小不為0) |
@NotBlank | 驗證註解的元素值不為空(不為null、去除首位空格後長度為0),不同於@NotEmpty,@NotBlank隻應用於字符串且在比較時會去除字符串的空格 |
驗證註解的元素值是Email,也可以通過正則表達式和flag指定自定義的email格式 |
Validation 支持如下幾種校驗,可以滿足基本的業務邏輯,當然如果還是滿足不瞭你的業務邏輯,可以選擇定制校驗規則。
定制校驗邏輯
定義校驗邏輯規則,實現 org.springframework.validation.Validator
public class ConfigPropertiesValidator implements Validator { @Override public boolean supports(Class<?> aClass) { return AppConfigProperties.class.isAssignableFrom(aClass); } @Override public void validate(Object o, Errors errors) { AppConfigProperties config = (AppConfigProperties) o; if(StringUtils.isEmpty(config.getId())){ errors.rejectValue("id", "app.id.empty", "[app.id] 屬性必須要在配置文件配置"); }else if (config.getId().length() < 5) { errors.rejectValue("id", "app.id.short", "[app.id] 屬性的長度必須不能小於5"); } } }
使用自定義校驗規則就不需要在使用原生的@NotEmpty瞭,將其刪除
@Validated @Data @ConfigurationProperties(prefix = "app") @Component public class AppConfigProperties { // @NotEmpty(message = "配置文件配置必須要配置[app.id]屬性") private String id; }
註入自定義校驗規則
@Bean public ConfigPropertiesValidator configurationPropertiesValidator(){ return new ConfigPropertiesValidator(); }
註意:這裡bean的方法名必須要 configurationPropertiesValidator,否則啟動的時候不會執行該校驗
修改app.id配置,觀察啟動情況
測試驗證結果
錯誤信息即為我們自定義校驗的結果。
小結
通過配置Spring Boot啟動校驗功能,可以快速的識別參數配置的錯誤,避免在使用組件的時候才發現問題,可以減少排查問題的工作量,並且在我們封裝自定義的starter時可以有更好的體驗。
以上就是SpringBoot開發技巧啟動時配置校驗實現示例的詳細內容,更多關於SpringBoot啟動時配置校驗的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- springmvc項目使用@Valid+BindingResult遇到的問題
- 解決get請求入參@NotNull驗證不生效問題
- SpringBoot參數校驗的方法總結
- Java實現優雅的參數校驗方法詳解
- 參數校驗Spring的@Valid註解用法解析