成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SpringBoot開發秘籍 - 集成參數校驗及高階技巧

開發 前端
對于 web服務來說,為防止非法參數對業務造成影響,在 Controller層一定要對參數進行校驗!本章我們以SpringBoot項目為例,介紹參數校驗的基本用法以及一些高級技巧,希望能對你有所幫助。

[[400097]]

本文轉載自微信公眾號「JAVA日知錄」,作者單一色調。轉載本文請聯系JAVA日知錄公眾號。

對于 web服務來說,為防止非法參數對業務造成影響,在 Controller層一定要對參數進行校驗!本章我們以SpringBoot項目為例,介紹參數校驗的基本用法以及一些高級技巧,希望能對你有所幫助。

簡單使用

1.要在Springboot項目中加入參數校驗功能首先得加入spring-boot-starter-validation依賴

  1. <dependency> 
  2.  <groupId>org.springframework.boot</groupId> 
  3.  <artifactId>spring-boot-starter-validation</artifactId> 
  4. </dependency> 

2.然后給需要校驗的字段添加上約束性注解,如我們對實體類參數進行校驗

  1. @Data 
  2. public class ValidEntity{ 
  3.     private int id; 
  4.     @NotBlank 
  5.     private String appId; 
  6.    
  7.     @NotBlank 
  8.     private String name
  9.    
  10.     @Email 
  11.     private String email; 

常見約束注解如下:

注解 功能
@AssertFalse 可以為null,如果不為null的話必須為false
@AssertTrue 可以為null,如果不為null的話必須為true
@DecimalMax 設置不能超過最大值
@DecimalMin 設置不能超過最小值
@Digits 設置必須是數字且數字整數的位數和小數的位數必須在指定范圍內
@Future 日期必須在當前日期的未來
@Past 日期必須在當前日期的過去
@Max 最大不得超過此最大值
@Min 最大不得小于此最小值
@NotNull 不能為null,可以是空
@Null 必須為null
@Pattern 必須滿足指定的正則表達式
@Size 集合、數組、map等的size()值必須在指定范圍內
@Email 必須是email格式
@Length 長度必須在指定范圍內
@NotBlank 字符串不能為null,字符串trim()后也不能等于“”
@NotEmpty 不能為null,集合、數組、map等size()不能為0;字符串trim()后可以等于“”
@Range 值必須在指定范圍內
@URL 必須是一個URL

注:此表格只是簡單的對注解功能的說明,并沒有對每一個注解的屬性進行說明;可詳見源碼。

3.在Controller層對需要參數校驗的方法加上@Validated注解

參數校驗一般分為兩類:在Controller使用模型接收數據時, @Validated注解直接放在該模型參數前即可。

  1. @PostMapping(value = "test1"
  2. public String test1(@Validated @RequestBody ValidEntity validEntity){ 
  3.  return "test1 valid success"
  4.  
  5. @PostMapping(value = "test3"
  6. public String test3(@Validated ValidEntity validEntity){ 
  7.  return "test3 valid success"

當我們是直接在Controller層中的參數前,使用約束注解時,@Validated要直接放在類上

  1. @PostMapping(value = "test2"
  2. public String test2(@Email String email){ 
  3.     return "test2 valid success"

此時需要在主類上增加@Validated注解

  1. @Validated 
  2. @RestController 
  3. @RequestMapping("/demo/valid"
  4. public class ValidController { 
  5.  ... 

在參數校驗時我們既可以使用@Validated也可以使用@Valid注解,兩者功能大部分類似;

主要區別在于:

@Valid屬于javax下的,而@Validated屬于spring下;

@Valid支持嵌套校驗、而@Validated不支持,@Validated支持分組,而@Valid不支持。

統一異常處理

如果參數校驗未通過Spring會拋出三種類型的異常

1.當對@RequestBody需要的參數進行校驗時會出現org.springframework.web.bind.MethodArgumentNotValidException

當直接校驗具體參數時會出現javax.validation.ConstraintViolationException,也屬于ValidationException異常

當直接校驗對象時會出現org.springframework.validation.BindException

在SpringBoot中統一攔截處理只需要在配置類上添加 @RestControllerAdvice注解,然后在具體方法中通過 @ExceptionHandler指定需要處理的異常,具體代碼如下:

  1. @RestControllerAdvice 
  2. @Slf4j 
  3. public class GlobalExceptionHandler { 
  4.     public static final String ERROR_MSG = "系統異常,請聯系管理員。"
  5.  
  6.     @ExceptionHandler(value = {BindException.class, ValidationException.class, MethodArgumentNotValidException.class}) 
  7.     public ResponseEntity<Result<String>> handleValidatedException(Exception e) { 
  8.         Result<String> resp = null
  9.  
  10.         if (e instanceof MethodArgumentNotValidException) { 
  11.             // BeanValidation exception 
  12.             MethodArgumentNotValidException ex = (MethodArgumentNotValidException) e; 
  13.             resp = new Result<>(Integer.toString(HttpStatus.BAD_REQUEST.value()), 
  14.                     ex.getBindingResult().getAllErrors().stream().map(ObjectError::getDefaultMessage).collect(Collectors.joining(", ")) 
  15.                     , getStackTrace(ex)); 
  16.         } else if (e instanceof ConstraintViolationException) { 
  17.             // BeanValidation GET simple param 
  18.             ConstraintViolationException ex = (ConstraintViolationException) e; 
  19.             resp = new Result<>(Integer.toString(HttpStatus.BAD_REQUEST.value()), 
  20.                     ex.getConstraintViolations().stream().map(ConstraintViolation::getMessage).collect(Collectors.joining(", ")) 
  21.                     , getStackTrace(ex)); 
  22.         } else if (e instanceof BindException) { 
  23.             // BeanValidation GET object param 
  24.             BindException ex = (BindException) e; 
  25.             resp = new Result<>(Integer.toString(HttpStatus.BAD_REQUEST.value()), 
  26.                     ex.getAllErrors().stream().map(ObjectError::getDefaultMessage).collect(Collectors.joining(", ")) 
  27.                     , getStackTrace(ex)); 
  28.         } 
  29.  
  30.         return new ResponseEntity<>(resp,HttpStatus.BAD_REQUEST); 
  31.     } 
  32.  
  33.  
  34.     private String getStackTrace(Exception e) { 
  35.         //打印日志開關,可通過配置讀取 
  36.         boolean printStrackTrace = false
  37.         if(printStrackTrace){ 
  38.             StringWriter sw = new StringWriter(); 
  39.             e.printStackTrace(new PrintWriter(sw)); 
  40.             return sw.toString(); 
  41.         }else
  42.             return ERROR_MSG; 
  43.         } 
  44.  
  45.     } 
  46.  

最終實現效果如下:

參數分組

有下面一個實體類,我們需要對其進行參數校驗。

  1. @Data 
  2. public class ValidEntity { 
  3.     private int id; 
  4.  
  5.     @NotBlank 
  6.     private String appId; 
  7.  
  8.     @NotBlank 
  9.     private String name
  10.  
  11.     @Email 
  12.     private String email; 

但是實際業務是在編輯的時候 appId才是必填,在新增的時候 name必填,這時候可以用groups分組功能來實現:同一個模型在不同場景下,動態區分校驗模型中的不同字段。

使用方式

首先我們定義一個分組接口ValidGroup,再在分組接口總定義出多個不同的操作類型,Create,Update,Query,Delete

  1. public interface ValidGroup extends Default
  2.    
  3.     interface Crud extends ValidGroup{ 
  4.        
  5.         interface Create extends Crud{ 
  6.  
  7.         } 
  8.      
  9.         interface Update extends Crud{ 
  10.  
  11.         } 
  12.        
  13.         interface Query extends Crud{ 
  14.  
  15.         } 
  16.    
  17.         interface Delete extends Crud{ 
  18.  
  19.         } 
  20.     } 

這里的 ValidGroup繼承了Default,當然也可以不繼承,具體區別我們后面再說。

在模型中給校驗參數分配分組

  1. @Data 
  2. @ApiModel(value="ValidEntity"
  3. public class ValidEntity { 
  4.     private int id; 
  5.  
  6.     @NotBlank(groups = ValidGroup.Crud.Update.class) 
  7.     private String appId; 
  8.  
  9.     @NotBlank(groups = ValidGroup.Crud.Create.class) 
  10.     private String name
  11.  
  12.     @Email 
  13.     private String email; 

tips:這里@Email注解未指定分組,默認會屬于Default分組,appId和name指定了分組就不會再屬于Default分組了。

在參數校驗時通過value屬性指定分組

這里通過 @Validated(value = ValidGroup.Crud.Update.class)指定了具體的分組,上面提到的是否繼承Default的區別在于:

如果繼承了Default,@Validated標注的注解也會校驗未指定分組或者Default分組的參數,比如email

如果不繼承Default則不會校驗未指定分組的參數,需要加上@Validated(value = {ValidGroup.Crud.Update.class, Default.class}才會校驗

快速失敗(Fali Fast)

默認情況下在對參數進行校驗時Spring Validation會校驗完所有字段然后才拋出異常,可以通過配置開啟 Fali Fast模式,一旦校驗失敗就立即返回。

  1. @Configuration 
  2. public class ValidatedConfig { 
  3.  
  4.     @Bean 
  5.     public Validator validator() { 
  6.         ValidatorFactory validatorFactory = Validation.byProvider(HibernateValidator.class) 
  7.                 .configure() 
  8.                 // 快速失敗模式 
  9.                 .failFast(true
  10.                 .buildValidatorFactory(); 
  11.         return validatorFactory.getValidator(); 
  12.     } 

以上,希望對你有所幫助!

 

責任編輯:武曉燕 來源: JAVA日知錄
相關推薦

2021-04-21 09:04:43

開發SpringBoot框架

2023-11-08 13:33:00

AOP技術信息

2023-03-16 08:23:33

2022-12-30 08:49:41

SpringBoot@Validated

2025-04-28 09:31:11

Springif 語句系統

2023-11-29 07:23:04

參數springboto

2022-05-03 10:43:43

SpringJava

2023-10-18 07:36:56

SpringBootJava

2025-02-10 08:49:40

2022-11-10 07:53:54

Spring參數校驗

2025-02-10 00:23:11

Spring微服務架構

2010-08-02 09:21:48

Flex模塊化

2024-07-29 00:00:05

2021-08-12 10:32:50

Spring Boot參數校驗分組校驗

2021-08-10 15:11:27

Spring Boot參數校驗

2022-09-01 06:54:28

CSS前端

2022-12-22 08:34:22

CSS不規則圖形

2023-03-31 08:10:50

2021-11-10 10:03:18

SpringBootJava代碼

2024-01-29 08:49:36

RAG模型檢索
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国外成人在线视频网站 | 人人干人人看 | 丁香综合 | 国产男女视频 | 欧美精品啪啪 | 午夜无码国产理论在线 | 精品色 | 午夜在线观看免费 | 三级高清 | 中文字幕高清免费日韩视频在线 | 亚洲视频区 | 日韩中文一区二区 | 亚洲欧美在线观看 | 久艹av| 国产精品日韩在线 | 精品一区二区三区在线观看国产 | 欧美精品一区二区免费 | 欧美日韩国产在线观看 | 免费看黄色国产 | 午夜精品在线观看 | 中文字幕一二三 | 人人人人爽 | 三级高清 | 日韩播放| 久久夜色精品国产 | 日韩久久成人 | 国产精品18hdxxxⅹ在线 | 欧美精品在线一区 | 久久久久亚洲精品 | 在线超碰| 免费在线一区二区三区 | 久久99精品久久久久久国产越南 | 九九九久久国产免费 | 超碰3| 嫩草影院黄 | 国产在线精品一区 | 色婷婷综合网站 | 成人免费在线 | 亚洲精品一区二区三区丝袜 | 亚洲高清av在线 | 草b视频|