Spring 使用Validation 驗(yàn)證框架的問題詳解
Spring Validation 驗(yàn)證框架對(duì)參數(shù)的驗(yàn)證機(jī)制提供了@Validated (Spring’s JSR-303 規(guī)范,是標(biāo)準(zhǔn) JSR-303 的一個(gè)變種),javax 提供了@Valid(標(biāo)準(zhǔn) JSR-303 規(guī)范),配合 BindingResult 可以直接提供參數(shù)驗(yàn)證結(jié)果。其中對(duì)于字段的特定驗(yàn)證注解,比如 @NotNull。兩者在檢驗(yàn) Controller 的入?yún)⑹欠穹弦?guī)范時(shí),使用@Validated 或者 @Valid 在基本驗(yàn)證功能上沒有太多區(qū)別。但是在分組、注解地方、嵌套驗(yàn)證等功能上兩個(gè)有所不同:
1.@Validated分組:提供分組功能,可在入?yún)Ⅱ?yàn)證時(shí),根據(jù)不同的分組采用不同的驗(yàn)證機(jī)制。可注解位置:可以用在類型、方法和方法參數(shù)上。但是不能用在成員屬性上嵌套驗(yàn)證:用在方法入?yún)⑸蠠o法單獨(dú)提供嵌套驗(yàn)證功能;不能用在成員屬性上;也無法提供框架進(jìn)行嵌套驗(yàn)證;能配合嵌套驗(yàn)證注解 @Valid 進(jìn)行嵌套驗(yàn)證。
2.@Valid分組:無分組功能可注解位置:可以用在方法、構(gòu)造函數(shù)、方法參數(shù)和成員屬性上(兩者是否能用于成員屬性上直接影響能否提供嵌套驗(yàn)證的功能)嵌套驗(yàn)證:用在方法入?yún)⑸蠠o法單獨(dú)提供嵌套驗(yàn)證功能;能夠用在成員屬性上,提示驗(yàn)證框架進(jìn)行嵌套驗(yàn)證;能配合嵌套驗(yàn)證注解@Valid進(jìn)行嵌套驗(yàn)證。
二、使用1. SpringBoot 2.3.0后需要添加依賴
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-validation</artifactId></dependency>
2. 配置 validation 使出現(xiàn)校驗(yàn)失敗即返回
@Configurationpublic class WebConfig { @Bean public Validator validator() {ValidatorFactory validatorFactory = Validation.byProvider(HibernateValidator.class).configure()//failFast的意思只要出現(xiàn)校驗(yàn)失敗的情況,就立即結(jié)束校驗(yàn),不再進(jìn)行后續(xù)的校驗(yàn)。.failFast(true).buildValidatorFactory(); return validatorFactory.getValidator(); } @Bean public MethodValidationPostProcessor methodValidationPostProcessor() {MethodValidationPostProcessor methodValidationPostProcessor = new MethodValidationPostProcessor();methodValidationPostProcessor.setValidator(validator());return methodValidationPostProcessor; }}
4. 編寫全局異常捕獲,捕獲驗(yàn)證失敗,統(tǒng)一返回
@Slf4j@ControllerAdvicepublic class ValidatedExceptionHandler { @ResponseBody @ExceptionHandler(BindException.class) public String exceptionHandler2(BindException exception) {BindingResult result = exception.getBindingResult();if (result.hasErrors()) { return result.getAllErrors().get(0).getDefaultMessage();}return '參數(shù)不可為空!'; } @ResponseBody @ExceptionHandler(MethodArgumentNotValidException.class) public String exceptionHandler2(MethodArgumentNotValidException exception) {BindingResult result = exception.getBindingResult();if (result.hasErrors()) { return result.getAllErrors().get(0).getDefaultMessage();}return '參數(shù)不可為空!'; }}
5. 定義Dto,在參數(shù)上添加注解校驗(yàn)
@Datapublic class ValidDto { @NotEmpty(message = 'name 不可為空!') private String name; @NotBlank(message = 'userId 不可為空!') private String userId; @Min(value = 1, message = '年齡有誤!') @Max(value = 120, message = '年齡有誤!') private int age; @NotBlank(message = '郵箱不可為空!') @Email(message = '郵箱有誤!') private String email; @NotBlank(message = 'mobile不可為空!') @Pattern(regexp = '^(13[0-9]|14[579]|15[0-3,5-9]|16[6]|17[0135678]|18[0-9]|19[89])d{8}$', message = '手機(jī)號(hào)碼有誤!') private String mobile; @NotNull(message = 'validVo 不可為空!') @Valid private ValidVo validVo; @NotEmpty(message = 'list1 不可為空!') @Size(min = 1, max = 2, message = 'list1 數(shù)據(jù)過大') @Valid private List<ValidVo> list1;}
@Datapublic class ValidVo { @NotBlank(message = 'gender is null') private String gender; @NotBlank(message = 'test is null') private String test;}
6. Controller
@RestController@RequestMapping('/valid')@CrossOriginpublic class ValidController { @GetMapping('/GetTest') public String getTest(@Valid ValidDto dto, BindingResult result) {if (result.hasErrors()) { return result.getAllErrors().get(0).getDefaultMessage();}return 'success'; } @GetMapping('/GetTest2') public String getTest2(@Validated ValidDto dto) {return 'success'; } @GetMapping('/GetTest3') public String getTest3(@Validated @RequestBody ValidDto dto) {return 'success'; }}
到此這篇關(guān)于Spring 使用Validation 驗(yàn)證框架的問題詳解的文章就介紹到這了,更多相關(guān)Spring Validation 驗(yàn)證框架內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. phpstudy apache開啟ssi使用詳解2. CentOS郵件服務(wù)器搭建系列—— POP / IMAP 服務(wù)器的構(gòu)建( Dovecot )3. .NET SkiaSharp 生成二維碼驗(yàn)證碼及指定區(qū)域截取方法實(shí)現(xiàn)4. IntelliJ IDEA創(chuàng)建web項(xiàng)目的方法5. 存儲(chǔ)于xml中需要的HTML轉(zhuǎn)義代碼6. docker容器調(diào)用yum報(bào)錯(cuò)的解決辦法7. django創(chuàng)建css文件夾的具體方法8. MyBatis JdbcType 與Oracle、MySql數(shù)據(jù)類型對(duì)應(yīng)關(guān)系說明9. ASP中實(shí)現(xiàn)字符部位類似.NET里String對(duì)象的PadLeft和PadRight函數(shù)10. javascript xml xsl取值及數(shù)據(jù)修改第1/2頁
