• @Valid和@Validated的总结区分(转)


    @Valid:

    @Valid注解用于校验,所属包为:javax.validation.Valid。

    ① 首先需要在实体类的相应字段上添加用于充当校验条件的注解,如:@Min,如下代码(age属于Girl类中的属性):

    @Min(value = 18,message = "未成年禁止入内")
    private Integer age;
    ② 其次在controller层的方法的要校验的参数上添加@Valid注解,并且需要传入BindingResult对象,用于获取校验失败情况下的反馈信息,如下代码:

    @PostMapping("/girls")  
    public Girl addGirl(@Valid Girl girl, BindingResult bindingResult) {  
        if(bindingResult.hasErrors()){  
            System.out.println(bindingResult.getFieldError().getDefaultMessage());  
            return null;  
        }  
        return girlResposity.save(girl);  
    }  

    bindingResult.getFieldError.getDefaultMessage()用于获取相应字段上添加的message中的内容,如:@Min注解中message属性的内容

    @Validated:


    @Valid是javax.validation里的。

    @Validated是@Valid 的一次封装,是Spring提供的校验机制使用。@Valid不提供分组功能

    @Validated的特殊用法

    1、分组

    当一个实体类需要多种验证方式时,例:对于一个实体类的id来说,新增的时候是不需要的,对于更新时是必须的。

    可以通过groups对验证进行分组

    分组接口类(通过向groups分配不同类的class对象,达到分组目的):

    package com.valid.interfaces;  
      
    public interface First {  
      
    }  

    实体类:

    package com.valid.pojo;  
      
    import javax.validation.constraints.Size;  
    import org.hibernate.validator.constraints.NotEmpty;  
      
    import com.valid.interfaces.First;  
      
    public class People {  
          
        //在First分组时,判断不能为空  
        @NotEmpty(groups={First.class})  
        private String id;  
          
        //name字段不为空,且长度在3-8之间  
        @NotEmpty  
        @Size(min=3,max=8)  
        private String name;  
      
        public String getName() {  
            return name;  
        }  
      
        public void setName(String name) {  
            this.name = name;  
        }  
      
        public String getId() {  
            return id;  
        }  
      
        public void setId(String id) {  
            this.id = id;  
        }  
    }  

    注:

    (1)不分配groups,默认每次都要进行验证

    (2)对一个参数需要多种验证方式时,也可通过分配不同的组达到目的。例:

    @NotEmpty(groups={First.class})  
    @Size(min=3,max=8,groups={Second.class})  
    private String name;  

    控制类:

    package com.valid.controller;  
      
    import org.springframework.stereotype.Controller;  
    import org.springframework.validation.BindingResult;  
    import org.springframework.validation.annotation.Validated;  
    import org.springframework.web.bind.annotation.RequestMapping;  
    import org.springframework.web.bind.annotation.ResponseBody;  
      
    import com.valid.interfaces.First;  
    import com.valid.pojo.People;  
      
    @Controller  
    public class FirstController {  
          
        @RequestMapping("/addPeople")  
        //不需验证ID  
        public @ResponseBody String addPeople(@Validated People p,BindingResult result)  
        {  
            System.out.println("people's ID:" + p.getId());  
            if(result.hasErrors())  
            {  
                return "0";  
            }  
            return "1";  
        }  
          
        @RequestMapping("/updatePeople")  
        //需要验证ID  
        public @ResponseBody String updatePeople(@Validated({First.class}) People p,BindingResult result)  
        {  
            System.out.println("people's ID:" + p.getId());  
            if(result.hasErrors())  
            {  
                return "0";  
            }  
            return "1";  
        }  
    }  

    注:
    @Validated没有添加groups属性时,默认验证没有分组的验证属性,如该例子:People的name属性。

    @Validated没有添加groups属性时,所有参数的验证类型都有分组(即本例中People的name的@NotEmpty、@Size都添加groups属性),则不验证任何参数

    2、组序列

    默认情况下,不同组别的约束验证是无序的,然而在某些情况下,约束验证的顺序却很重要。

    例:

    (1)第二个组中的约束验证依赖于一个稳定状态来运行,而这个稳定状态是由第一个组来进行验证的。

    (2)某个组的验证比较耗时,CPU 和内存的使用率相对比较大,最优的选择是将其放在最后进行验证。因此,在进行组验证的时候尚需提供一种有序的验证方式,这就提出了组序列的概念。
    一个组可以定义为其他组的序列,使用它进行验证的时候必须符合该序列规定的顺序。在使用组序列验证的时候,如果序列前边的组验证失败,则后面的组将不再给予验证。

    分组接口类 (通过@GroupSequence注解对组进行排序):

    package com.valid.interfaces;  
      
    public interface First {  
      
    }  
    package com.valid.interfaces;  
      
    public interface Second {  
      
    }  
    package com.valid.interfaces;  
      
    import javax.validation.GroupSequence;  
      
    @GroupSequence({First.class,Second.class})  
    public interface Group {  
      
    }  

    实体类:

    package com.valid.pojo;  
      
    import javax.validation.constraints.Size;  
    import org.hibernate.validator.constraints.NotEmpty;  
      
    import com.valid.interfaces.First;  
    import com.valid.interfaces.Second;  
      
    public class People {  
          
        //在First分组时,判断不能为空  
        @NotEmpty(groups={First.class})  
        private String id;  
          
        //name字段不为空,且长度在3-8之间  
        @NotEmpty(groups={First.class})  
        @Size(min=3,max=8,groups={Second.class})  
        private String name;  
      
        public String getName() {  
            return name;  
        }  
      
        public void setName(String name) {  
            this.name = name;  
        }  
      
        public String getId() {  
            return id;  
        }  
      
        public void setId(String id) {  
            this.id = id;  
        }  
    }  

    3、验证多个对象

    一个功能方法上处理多个模型对象时,需添加多个验证结果对象

    package com.valid.controller;  
      
    import org.springframework.stereotype.Controller;  
    import org.springframework.validation.BindingResult;  
    import org.springframework.validation.annotation.Validated;  
    import org.springframework.web.bind.annotation.RequestMapping;  
    import org.springframework.web.bind.annotation.ResponseBody;  
      
    import com.valid.pojo.People;  
    import com.valid.pojo.Person;  
      
    @Controller  
    public class FirstController {  
          
        @RequestMapping("/addPeople")  
        public @ResponseBody String addPeople(@Validated People p,BindingResult result,@Validated Person p2,BindingResult result2)  
        {  
            if(result.hasErrors())  
            {  
                return "0";  
            }  
            if(result2.hasErrors())  
            {  
                return "-1";  
            }  
            return "1";  
        }  
    }  

    ————————————————
    版权声明:本文为CSDN博主「高高程序猿」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/gaojp008/article/details/80583301

  • 相关阅读:
    阿里取消周报
    摇滚明星原则
    t
    B树、B+树索引算法原理(下)
    订单业务楼层化 view管理器和model管理器进行了model和view的全面封装处理 三端不得不在每个业务入口上线时约定好降级开关,于是代码中充满了各种各样的降级开关字段
    单元测试
    项目管理图 有任务分解、技术风险 风险预案
    CPU飙高,系统性能问题如何排查?

    如何让淘宝不卡顿? 读写比例 动态扩容 分布式化路线 mysql 优化
  • 原文地址:https://www.cnblogs.com/muxi0407/p/12108762.html
Copyright © 2020-2023  润新知