亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Spring 使用Validation 驗證框架的問題詳解

 更新時間:2021年07月30日 15:34:21   作者:小畢超  
Spring Boot在內部通過集成hibernate-validation已經實現了JSR-349驗證規(guī)范接口,在Spring Boot項目中只要直接使用就行了。 一般用在Controller中用于驗證前端傳來的參數。這篇文章給大家介紹Spring Validation 驗證框架的相關知識,感興趣的朋友一起看看吧

一、介紹

Spring Validation 驗證框架對參數的驗證機制提供了@Validated (Spring's JSR-303 規(guī)范,是標準 JSR-303 的一個變種),javax 提供了@Valid(標準 JSR-303 規(guī)范),配合 BindingResult 可以直接提供參數驗證結果。其中對于字段的特定驗證注解,比如 @NotNull。
兩者在檢驗 Controller 的入參是否符合規(guī)范時,使用@Validated 或者 @Valid 在基本驗證功能上沒有太多區(qū)別。但是在分組、注解地方、嵌套驗證等功能上兩個有所不同:

1.@Validated
分組:提供分組功能,可在入參驗證時,根據不同的分組采用不同的驗證機制。
可注解位置:可以用在類型、方法和方法參數上。但是不能用在成員屬性上
嵌套驗證:用在方法入參上無法單獨提供嵌套驗證功能;不能用在成員屬性上;也無法提供框架進行嵌套驗證;能配合嵌套驗證注解 @Valid 進行嵌套驗證。

2.@Valid
分組:無分組功能
可注解位置:可以用在方法、構造函數、方法參數和成員屬性上(兩者是否能用于成員屬性上直接影響能否提供嵌套驗證的功能)
嵌套驗證:用在方法入參上無法單獨提供嵌套驗證功能;能夠用在成員屬性上,提示驗證框架進行嵌套驗證;能配合嵌套驗證注解@Valid進行嵌套驗證。

二、使用

1. SpringBoot 2.3.0后需要添加依賴

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

2. 配置 validation 使出現校驗失敗即返回

@Configuration
public class WebConfig {
    @Bean
    public Validator validator() {
        ValidatorFactory validatorFactory = Validation.byProvider(HibernateValidator.class)
                .configure()
                //failFast的意思只要出現校驗失敗的情況,就立即結束校驗,不再進行后續(xù)的校驗。
                .failFast(true)
                .buildValidatorFactory();
 
        return validatorFactory.getValidator();
    }
 
    @Bean
    public MethodValidationPostProcessor methodValidationPostProcessor() {
        MethodValidationPostProcessor methodValidationPostProcessor = new MethodValidationPostProcessor();
        methodValidationPostProcessor.setValidator(validator());
        return methodValidationPostProcessor;
    }
}

4. 編寫全局異常捕獲,捕獲驗證失敗,統(tǒng)一返回

@Slf4j
@ControllerAdvice
public 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 "參數不可為空!";
    }

    @ResponseBody
    @ExceptionHandler(MethodArgumentNotValidException.class)
    public String exceptionHandler2(MethodArgumentNotValidException exception) {
        BindingResult result = exception.getBindingResult();
        if (result.hasErrors()) {
            return result.getAllErrors().get(0).getDefaultMessage();
        }
        return "參數不可為空!";
    }
}

5. 定義Dto,在參數上添加注解校驗

@Data
public 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 = "手機號碼有誤!")
    private String mobile;

    @NotNull(message = "validVo 不可為空!")
    @Valid
    private ValidVo validVo;

    @NotEmpty(message = "list1 不可為空!")
    @Size(min = 1, max = 2, message = "list1 數據過大")
    @Valid
    private List<ValidVo> list1;
}
@Data
public class ValidVo {
    @NotBlank(message = "gender is null")
    private String gender;
    @NotBlank(message = "test is null")
    private String test;
}

6. Controller

@RestController
@RequestMapping("/valid")
@CrossOrigin
public 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";
    }
}

到此這篇關于Spring 使用Validation 驗證框架的問題詳解的文章就介紹到這了,更多相關Spring Validation 驗證框架內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Java_Spring之基于注解的 AOP 配置

    Java_Spring之基于注解的 AOP 配置

    這篇文章主要介紹了Java_Spring中基于注解的AOP配置,我們要先進行環(huán)境的搭建,在進行注解配置,感興趣的同學可以參考閱讀
    2023-04-04
  • Java 讀寫Properties配置文件詳解

    Java 讀寫Properties配置文件詳解

    這篇文章主要介紹了Java 讀寫Properties配置文件詳解的相關資料,這里舉例說明該如何實現,具有參考價值,需要的朋友可以參考下
    2016-11-11
  • Mybatis中使用萬能的Map傳參實現

    Mybatis中使用萬能的Map傳參實現

    在編程中,有可能遇到我們的實體類或者數據庫中表的字段或參數過多的情況,那這時候用Map傳參是比較理想的選擇,本文就詳細的介紹一下如何使用,感興趣的可以了解下
    2021-07-07
  • Spring?Security認證的完整流程記錄

    Spring?Security認證的完整流程記錄

    相信大伙對Spring Security這個框架又愛又恨,愛它的強大,恨它的繁瑣,下面這篇文章主要給大家介紹了關于Spring?Security認證流程的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-01-01
  • 解決mybatis-plus自定義xml的坑

    解決mybatis-plus自定義xml的坑

    這篇文章主要介紹了解決mybatis-plus自定義xml的坑,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • SpringMVC整合websocket實現消息推送及觸發(fā)功能

    SpringMVC整合websocket實現消息推送及觸發(fā)功能

    這篇文章主要為大家詳細介紹了SpringMVC整合websocket實現消息推送及觸發(fā)功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • Log4j 配置日志打印時區(qū)的實現方法

    Log4j 配置日志打印時區(qū)的實現方法

    下面小編就為大家分享一篇Log4j 配置日志打印時區(qū)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • 關于SpingMVC的<context:component-scan>包掃描踩坑記錄

    關于SpingMVC的<context:component-scan>包掃描踩坑記錄

    這篇文章主要介紹了關于SpingMVC的<context:component-scan>包掃描踩坑記錄,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • springboot簡單實現單點登錄的示例代碼

    springboot簡單實現單點登錄的示例代碼

    本文主要介紹了springboot簡單實現單點登錄的示例代碼,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • 利用Spring IOC技術實現用戶登錄驗證機制

    利用Spring IOC技術實現用戶登錄驗證機制

    這篇文章主要為大家詳細介紹了Spring IOC技術實現用戶登錄驗證機制的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-10-10

最新評論