1. <strong id="7actg"></strong>
    2. <table id="7actg"></table>

    3. <address id="7actg"></address>
      <address id="7actg"></address>
      1. <object id="7actg"><tt id="7actg"></tt></object>

        @Validated 和 @Valid 有什么區(qū)別?

        共 5627字,需瀏覽 12分鐘

         ·

        2022-06-24 12:28

        不點藍字關(guān)注,我們哪來故事?

        概述

        • @Valid是使用Hibernate validation的時候使用
        • @Validated是只用Spring Validator校驗機制使用

        說明:java的JSR303聲明了@Valid這類接口,而Hibernate-validator對其進行了實現(xiàn)

        @Validation@Valid進行了二次封裝,在使用上并沒有區(qū)別,但在分組、注解位置、嵌套驗證等功能上有所不同,這里主要就這幾種情況進行說明。

        注解位置

        • @Validated:用在類型、方法和方法參數(shù)上。但不能用于成員屬性(field)
        • @Valid:可以用在方法、構(gòu)造函數(shù)、方法參數(shù)和成員屬性(field)上

        如果@Validated注解在成員屬性上,則會報不適用于field錯誤

        分組校驗

        • @Validated:提供分組功能,可以在參數(shù)驗證時,根據(jù)不同的分組采用不同的驗證機制
        • @Valid:沒有分組功能

        舉例:

        定義分組接口:

        public interface IGroupA {
        }
         
        public interface IGroupB {
        }

        定義需要檢驗的參數(shù)bean:

        public class StudentBean implements Serializable{
            @NotBlank(message = "用戶名不能為空")
            private String name;
            //只在分組為IGroupB的情況下進行驗證
            @Min(value = 18, message = "年齡不能小于18歲", groups = {IGroupB.class})
            private Integer age
        ;
            @Pattern(regexp = "^((13[0-9])|(14[5,7,9])|(15([0-3]|[5-9]))|(166)|(17[0,1,3,5,6,7,8])|(18[0-9])|(19[8|9]))\\d{8}$", message = "手機號格式錯誤")
            private String phoneNum;
            @Email(message = "郵箱格式錯誤")
            private String email;
            @MyConstraint
            private String className;

        測試代碼:

        檢驗分組為IGroupA的情況

        @RestController
        public class CheckController {
            @PostMapping("stu")
            public String addStu(@Validated({IGroupA.class}) @RequestBody StudentBean studentBean){
                return "add student success";
            }
        }

        測試:

        這里對分組IGroupB的就沒檢驗了

        如果把測試代碼改成下面這樣,看看測試結(jié)果

        @RestController
        public class CheckController {
            @PostMapping("stu")
            public String addStu(@Validated({IGroupA.class, IGroupB.class}) @RequestBody StudentBean studentBean){
                return "add student success";
            }
        }

        說明:

        1、不分 配groups,默認每次都要進行驗證

        2、對一個參數(shù)需要多種驗證方式時,也可通過分配不同的組達到目的。

        組序列

        默認情況下 不同級別的約束驗證是無序的,但是在一些情況下,順序驗證卻是很重要。

        一個組可以定義為其他組的序列,使用它進行驗證的時候必須符合該序列規(guī)定的順序。在使用組序列驗證的時候,如果序列前邊的組驗證失敗,則后面的組將不再給予驗證。

        舉例:

        定義組序列:

        @GroupSequence({Default.classIGroupA.classIGroupB.class})
        public interface IGroup 
        {
        }

        需要校驗的Bean,分別定義IGroupA對age進行校驗,IGroupB對className進行校驗:

        public class StudentBean implements Serializable{
            @NotBlank(message = "用戶名不能為空")
            private String name;
            @Min(value = 18, message = "年齡不能小于18歲", groups = IGroupA.class)
            private Integer age
        ;
            @Pattern(regexp = "^((13[0-9])|(14[5,7,9])|(15([0-3]|[5-9]))|(166)|(17[0,1,3,5,6,7,8])|(18[0-9])|(19[8|9]))\\d{8}$", message = "手機號格式錯誤")
            private String phoneNum;
            @Email(message = "郵箱格式錯誤")
            private String email;
            @MyConstraint(groups = IGroupB.class)
            private String className
        ;

        測試代碼:

        @RestController
        public class CheckController {
            @PostMapping("stu")
            public String addStu(@Validated({IGroup.class}) @RequestBody StudentBean studentBean){
                return "add student success";
            }
        }

        測試發(fā)現(xiàn),如果age出錯,那么對組序列在IGroupA后的IGroupB不進行校驗,即例子中的className不進行校驗,結(jié)果如下:

        嵌套校驗

        一個待驗證的pojo類,其中還包含了待驗證的對象,需要在待驗證對象上注解@Valid,才能驗證待驗證對象中的成員屬性,這里不能使用@Validated

        舉例:

        需要約束校驗的bean:

        public class TeacherBean {
            @NotEmpty(message = "老師姓名不能為空")
            private String teacherName;
            @Min(value = 1, message = "學(xué)科類型從1開始計算")
            private int type;
        public class StudentBean implements Serializable{
            @NotBlank(message = "用戶名不能為空")
            private String name;
            @Min(value = 18, message = "年齡不能小于18歲")
            private Integer age;
            @Pattern(regexp = "^((13[0-9])|(14[5,7,9])|(15([0-3]|[5-9]))|(166)|(17[0,1,3,5,6,7,8])|(18[0-9])|(19[8|9]))\\d{8}$", message = "手機號格式錯誤")
            private String phoneNum;
            @Email(message = "郵箱格式錯誤")
            private String email;
            @MyConstraint
            private String className;
         
            @NotNull(message = "任課老師不能為空")
            @Size(min = 1, message = "至少有一個老師")
            private List<TeacherBean> teacherBeans;

        注意:

        這里對teacherBeans只校驗了NotNull, 和 Size,并沒有對teacher信息里面的字段進行校驗,具體測試如下:

        這里teacher中的type明顯是不符合約束要求的,但是能檢測通過,是因為在student中并沒有做 嵌套校驗

        可以在teacherBeans中加上 @Valid,具體如下:

        @Valid
        @NotNull(message = "任課老師不能為空")
        @Size(min = 1, message = "至少有一個老師")
        private List<TeacherBean> teacherBeans;

        這里再來測試,會發(fā)現(xiàn)如下結(jié)果:

        ////// END //////
        ↓ 點擊下方關(guān)注,看更多架構(gòu)分享 ↓
        瀏覽 46
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        評論
        圖片
        表情
        推薦
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        1. <strong id="7actg"></strong>
        2. <table id="7actg"></table>

        3. <address id="7actg"></address>
          <address id="7actg"></address>
          1. <object id="7actg"><tt id="7actg"></tt></object>
            免费草逼网 | 国产专区在线播放 | 粉嫩欧美一区二区三区高清影视 | 99精品国产免费久久久久久按摩 | 日韩一级免费观看 | 天天日天天射av 性无码一区 | sao货水真多把你cao烂69视频 | 日本女人高潮视频 | 韩国激情hd中文字幕 | 亚洲欧洲视频 |