91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何進行SpringBoot開發的集成參數校驗

發布時間:2021-09-14 15:49:07 來源:億速云 閱讀:169 作者:柒染 欄目:web開發

這期內容當中小編將會給大家帶來有關如何進行SpringBoot開發的集成參數校驗,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

對于 web服務來說,為防止非法參數對業務造成影響,在  Controller層一定要對參數進行校驗!

簡單使用

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

<dependency>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-validation</artifactId> </dependency>

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

@Data public class ValidEntity{     private int id;     @NotBlank     private String appId;        @NotBlank     private String name;        @Email     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注解直接放在該模型參數前即可。

@PostMapping(value = "test1") public String test1(@Validated @RequestBody ValidEntity validEntity){  return "test1 valid success"; }  @PostMapping(value = "test3") public String test3(@Validated ValidEntity validEntity){  return "test3 valid success"; }

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

@PostMapping(value = "test2") public String test2(@Email String email){     return "test2 valid success"; }

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

@Validated @RestController @RequestMapping("/demo/valid") public class ValidController {  ... }

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

主要區別在于:

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

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

統一異常處理

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

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

如何進行SpringBoot開發的集成參數校驗

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

如何進行SpringBoot開發的集成參數校驗

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

如何進行SpringBoot開發的集成參數校驗

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

@RestControllerAdvice @Slf4j public class GlobalExceptionHandler {     public static final String ERROR_MSG = "系統異常,請聯系管理員。";      @ExceptionHandler(value = {BindException.class, ValidationException.class, MethodArgumentNotValidException.class})     public ResponseEntity<Result<String>> handleValidatedException(Exception e) {         Result<String> resp = null;          if (e instanceof MethodArgumentNotValidException) {             // BeanValidation exception             MethodArgumentNotValidException ex = (MethodArgumentNotValidException) e;             resp = new Result<>(Integer.toString(HttpStatus.BAD_REQUEST.value()),                     ex.getBindingResult().getAllErrors().stream().map(ObjectError::getDefaultMessage).collect(Collectors.joining(", "))                     , getStackTrace(ex));         } else if (e instanceof ConstraintViolationException) {             // BeanValidation GET simple param             ConstraintViolationException ex = (ConstraintViolationException) e;             resp = new Result<>(Integer.toString(HttpStatus.BAD_REQUEST.value()),                     ex.getConstraintViolations().stream().map(ConstraintViolation::getMessage).collect(Collectors.joining(", "))                     , getStackTrace(ex));         } else if (e instanceof BindException) {             // BeanValidation GET object param             BindException ex = (BindException) e;             resp = new Result<>(Integer.toString(HttpStatus.BAD_REQUEST.value()),                     ex.getAllErrors().stream().map(ObjectError::getDefaultMessage).collect(Collectors.joining(", "))                     , getStackTrace(ex));         }          return new ResponseEntity<>(resp,HttpStatus.BAD_REQUEST);     }       private String getStackTrace(Exception e) {         //打印日志開關,可通過配置讀取         boolean printStrackTrace = false;         if(printStrackTrace){             StringWriter sw = new StringWriter();             e.printStackTrace(new PrintWriter(sw));             return sw.toString();         }else{             return ERROR_MSG;         }      }  }

最終實現效果如下:

如何進行SpringBoot開發的集成參數校驗

參數分組

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

@Data public class ValidEntity {     private int id;      @NotBlank     private String appId;      @NotBlank     private String name;      @Email     private String email; }

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

使用方式

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

public interface ValidGroup extends Default{        interface Crud extends ValidGroup{                interface Create extends Crud{          }              interface Update extends Crud{          }                interface Query extends Crud{          }            interface Delete extends Crud{          }     } }

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

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

@Data @ApiModel(value="ValidEntity") public class ValidEntity {     private int id;      @NotBlank(groups = ValidGroup.Crud.Update.class)     private String appId;      @NotBlank(groups = ValidGroup.Crud.Create.class)     private String name;      @Email     private String email; }

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

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

如何進行SpringBoot開發的集成參數校驗

這里通過 @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模式,一旦校驗失敗就立即返回。

@Configuration public class ValidatedConfig {      @Bean     public Validator validator() {         ValidatorFactory validatorFactory = Validation.byProvider(HibernateValidator.class)                 .configure()                 // 快速失敗模式                 .failFast(true)                 .buildValidatorFactory();         return validatorFactory.getValidator();     } }

上述就是小編為大家分享的如何進行SpringBoot開發的集成參數校驗了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

西盟| 崇阳县| 龙井市| 丰台区| 无棣县| 同江市| 云安县| 东兰县| 永兴县| 虎林市| 赤水市| 广东省| 涞水县| 荃湾区| 新民市| 久治县| 黎城县| 长汀县| 页游| 奉贤区| 涟源市| 泗水县| 门源| 利津县| 新建县| 松溪县| 泰安市| 福安市| 鄂伦春自治旗| 陵水| 富源县| 色达县| 班戈县| 莱州市| 翁牛特旗| 洛南县| 齐齐哈尔市| 阳高县| 磐石市| 天津市| 临泉县|