Spring Boot使用JSR-380進行校驗的示例
介紹
JSR-380
是 J2EE 的一個規(guī)范,用于校驗實體屬性,它是 JSR-303
的升級版,在 Spring Boot 中可以基于它優(yōu)雅實現(xiàn)參數(shù)校驗。
<!--more-->
示例
在沒有使用 JSR-380
之前,我們一般都會將參數(shù)校驗硬編碼在 controller
類中,示例:
public Result add(@RequestBody User user){ if(StringUtils.isBlank(user.getName())){ return Result.error("用戶名不能為空"); } // ... }
而使用 JSR-380
只需要通過添加對應(yīng)的注解即可實現(xiàn)校驗,示例:
@Data public class User{ @NotBlank private String name; private Integer age; }
public Result register(@Validated @RequestBody User user){ // ... }
這樣看起來代碼是不是清爽了很多,只需要在需要校驗的字段上加上對應(yīng)的校驗注解,然后對需要校驗的地方加上 @Validated
注解,然后框架就會幫我們完成校驗。
通過全局異常自定義錯誤響應(yīng)
框架校驗失敗之后會拋出異常,需要捕獲這個異常然后來自定義校驗不通過的錯誤響應(yīng),這里直接貼代碼,兼容 @RequestBody
、 @ModelAttribute
、 @RequestParam
三種入?yún)⒌男r灒?/p>
@ControllerAdvice public class GlobalExceptionHandler { @ExceptionHandler(value = {MethodArgumentNotValidException.class, BindException.class}) public ResponseEntity<Result> methodArgumentNotValidHandler(HttpServletRequest request, Exception e) { BindingResult bindingResult; if (e instanceof MethodArgumentNotValidException) { //@RequestBody參數(shù)校驗 bindingResult = ((MethodArgumentNotValidException) e).getBindingResult(); } else { //@ModelAttribute參數(shù)校驗 bindingResult = ((BindException) e).getBindingResult(); } FieldError fieldError = bindingResult.getFieldError(); return ResponseEntity.ok(Result.fail(Result.CODE_PARAMS_INVALID, "[" + fieldError.getField() + "]" + fieldError.getDefaultMessage())); } //@RequestParam參數(shù)校驗 @ExceptionHandler(value = {ConstraintViolationException.class, MissingServletRequestParameterException.class}) public ResponseEntity<Result> constraintViolationHandler(Exception e) { String field; String msg; if (e instanceof ConstraintViolationException) { ConstraintViolation<?> constraintViolation = ((ConstraintViolationException) e).getConstraintViolations().stream().findFirst().get(); List<Path.Node> pathList = StreamSupport.stream(constraintViolation.getPropertyPath().spliterator(), false) .collect(Collectors.toList()); field = pathList.get(pathList.size() - 1).getName(); msg = constraintViolation.getMessage(); } else { // 這個不是JSR標準返回的異常,要自定義提示文本 field = ((MissingServletRequestParameterException) e).getParameterName(); msg = "不能為空"; } return ResponseEntity.ok(Result.fail(Result.CODE_PARAMS_INVALID, "[" + field + "]" + msg)); } }
然后再訪問一下接口,可以看到錯誤提示已經(jīng)按自定義的規(guī)范顯示了:
可以看到都不需要寫任何提示文本就可以完成校驗和提示,上圖的 不能為空
是框架內(nèi)置的 I18N
國際化支持,每個注解都內(nèi)置相應(yīng)的提示模板。
常用校驗注解
注解 | 描述 |
---|---|
@NotNull | 驗證值不為 null |
@AssertTrue | 驗證值為 true |
@Size | 驗證值的長度介于 min 和 max 之間,可應(yīng)用于 String、Collection、Map 和數(shù)組類型 |
@Min | 驗證值不小于該值 |
@Max | 驗證值不大于該值 |
驗證字符串是有效的電子郵件地址 | |
@NotEmpty | 驗證值不為 null 或空,可應(yīng)用于 String、Collection、Map 和數(shù)組類型 |
@NotBlank | 驗證字符串不為 null 并且不是空白字符 |
@Positive | 驗證數(shù)字為正數(shù) |
@PositiveOrZero | 驗證數(shù)字為正數(shù)(包括 0) |
@Negative | 驗證數(shù)字為負數(shù) |
@NegativeOrZero | 驗證數(shù)字為負數(shù)(包括 0) |
@Past | 驗證日期值是過去 |
@PastOrPresent | 驗證日期值是過去(包括現(xiàn)在) |
@Future | 驗證日期值是未來 |
@FutureOrPresent | 驗證日期值是未來(包括現(xiàn)在) |
本文完整代碼放在 github 。
到此這篇關(guān)于Spring Boot使用JSR-380進行校驗的文章就介紹到這了,更多相關(guān)Spring Boot使用JSR-380校驗內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java、php、C#、asp實現(xiàn)短信群發(fā)功能的方法
這篇文章主要介紹了java、php、C#、asp實現(xiàn)短信群發(fā)功能的方法,以實例形式較為詳細的分析了java及php、C#、asp、VB.NET等調(diào)用短信發(fā)送接口進行短信發(fā)送的功能,需要的朋友可以參考下2015-02-02java編程隊列數(shù)據(jù)結(jié)構(gòu)代碼示例
這篇文章主要介紹了java編程隊列數(shù)據(jù)結(jié)構(gòu)代碼示例,簡單介紹了隊列的相關(guān)基礎(chǔ)知識,然后通過實例向大家展示其實現(xiàn)方法,具有一定參考價值,需要的朋友可以了解下。2017-11-11SpringCloud Zuul過濾器實現(xiàn)登陸鑒權(quán)代碼實例
這篇文章主要介紹了SpringCloud Zuul過濾器實現(xiàn)登陸鑒權(quán)代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-03-03關(guān)于SpringBoot禁止循環(huán)依賴解說
這篇文章主要介紹了關(guān)于SpringBoot禁止循環(huán)依賴解說,Spring的Bean管理,文章圍繞主題展開詳細介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-05-05MybatisPlus多數(shù)據(jù)源及事務(wù)解決思路
這篇文章主要介紹了MybatisPlus多數(shù)據(jù)源及事務(wù)解決思路,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01