国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Spring Boot參數校驗以及分組校驗的使用

開發 開發工具
做web開發有一點很煩人就是要對前端輸入參數進行校驗,基本上每個接口都要對參數進行校驗,比如一些非空校驗、格式校驗等。如果參數比較少的話還是容易處理的一但參數比較多了的話代碼中就會出現大量的if-else語句。

 [[416602]]

一 前言

做web開發有一點很煩人就是要對前端輸入參數進行校驗,基本上每個接口都要對參數進行校驗,比如一些非空校驗、格式校驗等。如果參數比較少的話還是容易處理的一但參數比較多了的話代碼中就會出現大量的if-else語句。

使用這種方式雖然簡單直接,但是也有不好的地方,一是降低了開發效率,因為我們需要校驗的參數會存在很多地方,并且不同地方會有重復校驗,其次降低了代碼可讀性,因為在業務代碼中摻雜了太多額外工作的代碼。

所以我們可以使用validator組件來代替我們進行不必要的coding操作。本文基于validator的介紹資料,也結合自己在項目中的實際使用經驗進行了總結,希望能幫到大家。

1 什么是validator

Bean Validation是Java定義的一套基于注解的數據校驗規范,目前已經從JSR 303的1.0版本升級到JSR 349的1.1版本,再到JSR 380的2.0版本(2.0完成于2017.08),已經經歷了三個版本 。需要注意的是,JSR只是一項標準,它規定了一些校驗注解的規范,但沒有實現,比如@Null、@NotNull、@Pattern等,它們位于 javax.validation.constraints這個包下。而hibernate validator是對這個規范的實現,并增加了一些其他校驗注解,如 @NotBlank、@NotEmpty、@Length等,它們位于org.hibernate.validator.constraints這個包下。

如果我們的項目使用了Spring Boot,hibernate validator框架已經集成在 spring-boot-starter-web中,所以無需再添加其他依賴。如果不是Spring Boot項目,需要添加如下依賴。

  1. <dependency> 
  2.     <groupId>org.hibernate.validator</groupId> 
  3.     <artifactId>hibernate-validator</artifactId> 
  4.     <version>6.0.8.Final</version> 
  5. </dependency> 

 

二 注解介紹

1 validator內置注解

 

 

 

 


 

 

 

注解 說明
@Null 被注釋的元素必須為null
@NotNull 被注釋的元素不能為null
@AssertTrue 被注釋的元素必須為true
@AssertFalse 被注釋的元素必須為false
@Min(value) 被注釋的元素必須是一個數字,其值必須大于等于指定的最小值
@Max(value) 被注釋的元素必須是一個數字,其值必須小于等于指定的最大值
@DecimalMin(value) 被注釋的元素必須是一個數字,其值必須大于等于指定的最小值
@DecimalMax(value) 被注釋的元素必須是一個數字,其值必須小于等于指定的最大值
@Size(max,min) 被注釋的元素的大小必須在指定的范圍內
@Digits(integer, fraction) 被注釋的元素必須是一個數字,其值必須必須在可接受的范圍內
@Past 被注釋的元素必須是一個過去的日期
@Future 被注釋的元素必須是一個將來的日期
@Pattern(value) 被注釋的元素必須符合指定的正則表達式

hibernate validator中擴展定義了如下注解:

注解 說明
@NotBlank 被注釋的元素不能為null,且長度必須大于0,只能用于注解字符串
@Email 被注釋的元素必須是電子郵箱地址
@Length(min=,max=) 被注釋的字符串的大小必須在指定的范圍內
@NotEmpty 被注釋的元素值不為null且不為空,支持字符串、集合、Map和數組類型
@Range 被注釋的元素必須在規定的范圍內

三 使用

使用起來比較簡單,都是使用注解方式使用。具體來說分為單參數校驗、對象參數校驗,單參數校驗就是controller接口按照單參數接收前端傳值,沒有封裝對象進行接收,如果有封裝對象那就是對象參數校驗。

1 單參數校驗

單參數校驗只需要在參數前添加注解即可,如下所示:

  1. public Result deleteUser(@NotNull(message = "id不能為空") Long id) { 
  2.   // do something 

但有一點需要注意,如果使用單參數校驗,controller類上必須添加@Validated注解,如下所示:

  1. @RestController 
  2. @RequestMapping("/user"
  3. @Validated // 單參數校驗需要加的注解 
  4. public class UserController { 
  5.   // do something 

2 對象參數校驗

對象參數校驗使用時,需要先在對象的校驗屬性上添加注解,然后在Controller方法的對象參數前添加@Validated 注解,如下所示:

  1. public Result addUser(@Validated UserAO userAo) { 
  2.     // do something 
  3.  
  4. public class UserAO { 
  5.   @NotBlank 
  6.   private String name
  7.  
  8.   @NotNull 
  9.   private Integer age; 
  10.    
  11.   …… 

注解分組

在對象參數校驗場景下,有一種特殊場景,同一個參數對象在不同的場景下有不同的校驗規則。比如,在創建對象時不需要傳入id字段(id字段是主鍵,由系統生成,不由用戶指定),但是在修改對象時就必須要傳入id字段。在這樣的場景下就需要對注解進行分組。

1)組件有個默認分組Default.class, 所以我們可以再創建一個分組UpdateAction.class,如下所示:

  1. public interface UpdateAction { 

2)在參數類中需要校驗的屬性上,在注解中添加groups屬性:

  1. public class UserAO { 
  2.  
  3.     @NotNull(groups = UpdateAction.class, message = "id不能為空"
  4.     private Long id; 
  5.      
  6.     @NotBlank 
  7.     private String name
  8.  
  9.     @NotNull 
  10.     private Integer age; 
  11.      
  12.     …… 

如上所示,就表示只在UpdateAction分組下校驗id字段,在默認情況下就會校驗name字段和age字段。

然后在controller的方法中,在@Validated注解里指定哪種場景即可,沒有指定就代表采用Default.class,采用其他分組就需要顯示指定。如下代碼便表示在addUser()接口中按照默認情況進行參數校驗,在updateUser()接口中按照默認情況和UpdateAction分組對參數進行共同校驗。

  1. public Result addUser(@Validated UserAO userAo) { 
  2.   // do something 
  1. public Result updateUser(@Validated({Default.class, UpdateAction.class}) UserAO userAo) { 
  2.   // do something 

對象嵌套

如果需要校驗的參數對象中還嵌套有一個對象屬性,而該嵌套的對象屬性也需要校驗,那么就需要在該對象屬性上增加@Valid注解。

  1. public class UserAO { 
  2.  
  3.     @NotNull(groups = UpdateAction.class, message = "id不能為空"
  4.     private Long id; 
  5.      
  6.     @NotBlank 
  7.     private String name
  8.  
  9.     @NotNull 
  10.     private Integer age; 
  11.      
  12.     @Valid 
  13.     private Phone phone; 
  14.      
  15.     …… 
  16.  
  17. public class Phone { 
  18.     @NotBlank 
  19.     private String operatorType; 
  20.      
  21.     @NotBlank 
  22.     private String phoneNum; 

3 錯誤消息的捕獲

參數校驗失敗后會拋出異常,我們只需要在全局異常處理類中捕獲參數校驗的失敗異常,然后將錯誤消息添加到返回值中即可。捕獲異常的方法如下所示,返回值Result是我們系統自定義的返回值類。

  1. @RestControllerAdvice(basePackages= {"com.alibaba.dc.controller","com.alibaba.dc.service"}) 
  2. public class GlobalExceptionHandler { 
  3.  
  4.   @ExceptionHandler(value = {Throwable.class}) 
  5.   Result handleException(Throwable e, HttpServletRequest request){ 
  6.     // 異常處理 
  7.         } 

需要注意的是,如果缺少參數拋出的異常是MissingServletRequestParameterException,單參數校驗失敗后拋出的異常是ConstraintViolationException,get請求的對象參數校驗失敗后拋出的異常是BindException,post請求的對象參數校驗失敗后拋出的異常是MethodArgumentNotValidException,不同異常對象的結構不同,對異常消息的提取方式也就不同。如下圖所示:

1)MissingServletRequestParameterException

  1. if(e instanceof MissingServletRequestParameterException){ 
  2.     Result result = Result.buildErrorResult(ErrorCodeEnum.PARAM_ILLEGAL); 
  3.     String msg = MessageFormat.format("缺少參數{0}", ((MissingServletRequestParameterException) e).getParameterName()); 
  4.     result.setMessage(msg); 
  5.     return result; 

2)ConstraintViolationException異常

  1. if(e instanceof ConstraintViolationException){ 
  2.   // 單個參數校驗異常 
  3.   Result result = Result.buildErrorResult(ErrorCodeEnum.PARAM_ILLEGAL); 
  4.   Set<ConstraintViolation<?>> sets = ((ConstraintViolationException) e).getConstraintViolations(); 
  5.   if(CollectionUtils.isNotEmpty(sets)){ 
  6.     StringBuilder sb = new StringBuilder(); 
  7.     sets.forEach(error -> { 
  8.                     if (error instanceof FieldError) { 
  9.                         sb.append(((FieldError)error).getField()).append(":"); 
  10.                     } 
  11.                     sb.append(error.getMessage()).append(";"); 
  12.                 }); 
  13.     String msg = sb.toString(); 
  14.     msg = StringUtils.substring(msg, 0, msg.length() -1); 
  15.     result.setMessage(msg); 
  16.   } 
  17.   return result; 

3)BindException異常

  1. if (e instanceof BindException){ 
  2.       // get請求的對象參數校驗異常 
  3.       Result result = Result.buildErrorResult(ErrorCodeEnum.PARAM_ILLEGAL); 
  4.       List<ObjectError> errors = ((BindException) e).getBindingResult().getAllErrors(); 
  5.       String msg = getValidExceptionMsg(errors); 
  6.       if (StringUtils.isNotBlank(msg)){ 
  7.         result.setMessage(msg); 
  8.       } 
  9.       return result; 
  1. private String getValidExceptionMsg(List<ObjectError> errors) { 
  2.   if(CollectionUtils.isNotEmpty(errors)){ 
  3.     StringBuilder sb = new StringBuilder(); 
  4.     errors.forEach(error -> { 
  5.                     if (error instanceof FieldError) { 
  6.                        sb.append(((FieldError)error).getField()).append(":"); 
  7.                     } 
  8.                     sb.append(error.getDefaultMessage()).append(";"); 
  9.                 }); 
  10.     String msg = sb.toString(); 
  11.     msg = StringUtils.substring(msg, 0, msg.length() -1); 
  12.     return msg; 
  13.   } 
  14.   return null

4)MethodArgumentNotValidException異常

  1. if (e instanceof MethodArgumentNotValidException){ 
  2.       // post請求的對象參數校驗異常 
  3.       Result result = Result.buildErrorResult(ErrorCodeEnum.PARAM_ILLEGAL); 
  4.       List<ObjectError> errors = ((MethodArgumentNotValidException) e).getBindingResult().getAllErrors(); 
  5.       String msg = getValidExceptionMsg(errors); 
  6.       if (StringUtils.isNotBlank(msg)){ 
  7.         result.setMessage(msg); 
  8.       } 
  9.       return result; 

【本文為51CTO專欄作者“阿里巴巴官方技術”原創稿件,轉載請聯系原作者】

戳這里,看該作者更多好文

 

責任編輯:武曉燕 來源: 51CTO專欄
相關推薦

2021-08-12 10:32:50

Spring Boot參數校驗分組校驗

2022-11-10 07:53:54

Spring參數校驗

2025-05-27 07:07:29

2025-10-27 02:00:00

2024-08-06 11:17:58

SpringJSON數據

2021-10-22 14:50:23

Spring BootJava

2023-03-09 12:04:38

Spring文件校驗

2025-04-29 07:44:26

配置校驗機制

2023-03-16 08:23:33

2022-12-30 08:49:41

SpringBoot@Validated

2025-05-14 00:00:00

2022-04-21 09:59:53

Nest參數校驗

2023-03-28 08:07:12

2023-11-29 07:23:04

參數springboto

2024-06-19 10:04:15

ifC#代碼

2025-01-06 09:51:51

2023-09-27 08:14:56

2020-09-27 11:35:16

Spring BootStarterJava

2021-05-18 09:25:54

SpringBoot參數校驗

2022-05-03 10:43:43

SpringJava
點贊
收藏

51CTO技術棧公眾號

狠狠色噜噜狠狠狠狠色吗综合| 日本免费精品| 成人免费无遮挡| 亚洲国产精品中文| 日韩一级片免费视频| 久久久国产一区二区三区四区小说 | 青青青在线视频播放| 午夜视黄欧洲亚洲| 成人在线视频播放| 2019国产精品视频| 99亚洲伊人久久精品影院| 成人免费午夜电影| 久久免费电影网| 激情在线视频播放| 91亚洲精品久久久| 欧美国产成人精品| 中文字幕成在线观看| 国产综合色一区二区三区| 日韩理论片在线| 成人国产激情在线| 亚洲精品一区二区三区av| 亚洲一二三四区| 亚洲成人黄色| 日韩欧美第一区| 99久久综合| 69日小视频在线观看| 日韩中文字幕在线精品| 亚洲欧美日韩精品一区二区 | 综合136福利视频在线| 一道本一区二区| 波多野结衣在线| 成人激情综合网站| 在线观看a级片| 99www免费人成精品| 亚洲在线视频一区| 精品素人av| 亚洲爆乳无码专区| 亚洲最新av在线| 91超碰在线播放| 国产在线精品一区二区三区| 一区二区三区高清不卡| 亚洲欧美日韩一级| 国产精品18久久久久久久久 | 中文字幕亚洲一区二区三区| 日韩精品电影在线| 在线中文资源天堂| 91亚洲国产成人精品性色| 亚洲一区二区在线观看视频| 天堂综合网久久| 在线看的黄色网址| 欧美巨猛xxxx猛交黑人97人| 国产99久久精品| 欧美aa视频| 99热一区二区三区| 亚洲国产精品系列| 久久草av在线| 人狥杂交一区欧美二区| 一区不卡视频| 亚洲精品videossex少妇| 另类小说综合欧美亚洲| 成年女人在线看片| 日本道在线视频| 国产一区二区三区欧美| 成人性生交大片免费| 成人做爰免费视频免费看| 成人免费毛片在线观看| 久久国产精品久久久久久久久久 | 97精品久久久午夜一区二区三区| 欧美成人黑人| 国产青青在线视频| 久久综合久久八八| 国产精品久久午夜| 人人精品亚洲| 日本性视频网| 川上优av一区二区线观看| 亚洲综合色噜噜狠狠| 欧美电影一区| 欧洲美女少妇精品| 亚洲精品乱码久久久久久蜜桃91| 日韩电影中文字幕在线| 暴力调教一区二区三区| 一区二区免费| 男人天堂午夜在线| 精品国产一区二区三区四区vr| 欧美一区二区三区精品| 国产美女精品人人做人人爽| 欧美天堂一区二区| 国产网红在线| 91影院未满十八岁禁止入内| 欧美一级搡bbbb搡bbbb| 国产电影精品久久禁18| 久久动漫网址| 国产福利小视频在线| 伊人久久大香线蕉av一区| 综合国产在线视频| 亚洲精品欧美在线| 亚洲永久免费精品| 亚洲国产天堂| 色综合888| 亚洲欧美日韩在线综合| 久久久久久久久久久久久久久久久久av | 国产精品一区二区精品视频观看 | 日韩精品电影在线观看| 制服国产精品| 在线激情视频| 福利视频在线导航| а√中文在线8| 国产精品成人**免费视频| 国产三级国产精品国产专区50| 日韩av电影免费观看| 97超碰色婷婷| 日韩精品一区二区三区中文不卡 | 亚洲欧洲高清在线| 久久精品一区蜜桃臀影院| 精品久久91| 青草视频在线免费直播| 国产精品人人妻人人爽人人牛| 国产日韩欧美电影在线观看| 精品对白一区国产伦| 中日韩av电影| 136国产福利精品导航网址| 欧美videos粗暴| 三级做a全过程在线观看| 国产精品亚洲天堂| 日本韩国在线不卡| 欧美一区二区播放| 国产色产综合色产在线视频| 亚洲国产日本| 伊人精品综合| a级网站在线播放| av手机天堂| 91免费视频黄| 国产综合久久久久| 久久国产精品影片| 日韩欧美黄色影院| 亚洲成人自拍偷拍| 99久久久久久99| 国产亚洲激情| 日韩欧美国产大片| 日韩三区免费| 免费**毛片在线| 黄色三级电影网| 欧美狂野激情性xxxx在线观| 91原创国产| 97国产真实伦对白精彩视频8| 欧美一区二区三区公司| 亚洲卡通动漫在线| 99精品视频在线观看免费| 首页亚洲欧美制服丝腿| 日韩精品二区| 国产美女撒尿一区二区| 亚洲成av在线| av剧情在线观看| 波多野结衣在线网站| 国产乱子视频| 精品一区二区中文字幕| 伊人狠狠色丁香综合尤物| 99久久精品免费看国产四区| 欧美做受高潮电影o| xvideos亚洲人网站| 欧美videofree性高清杂交| 色999日韩国产欧美一区二区| 中文字幕电影一区| 波多野洁衣一区| 国产一区二区精品在线观看| 欧美专区18| 影音先锋中文字幕一区| 成人三级视频| 亚洲综合图色| 国产精品天天看天天狠| 免费视频观看成人| 国产精品亚洲一区二区三区在线观看| 免费在线毛片网站| 免费av片风间由美在线| 日韩av网站在线免费观看| 成人午夜大片免费观看| 精品久久久久久亚洲综合网| 国产一区玩具在线观看| 亚洲一区二区三区免费观看| 免费高清在线观看免费| 嫩模私拍啪啪| 欧美视频一二三| 91首页免费视频| 国产福利精品一区| 国产在线观看一区二区| 麻豆视频观看网址久久| 日韩电影在线一区二区| 久久亚洲美女| 国产精品一二| 久久成人精品| 丝袜美腿高跟呻吟高潮一区| 久久久免费高清电视剧观看| 午夜精品电影在线观看| 福利在线播放| 欧美a在线观看| 黄av在线播放| 97精品久久久久中文字幕| 菠萝菠萝蜜在线视频免费观看| 久久99久久| 欧美777四色影视在线|