欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

spring注解之@Valid和@Validated的區(qū)分總結(jié)

 更新時(shí)間:2022年03月30日 10:51:02   作者:高高程序猿高高程序猿高高程序猿高高程序猿  
@Validated和@Valid在基本驗(yàn)證功能上沒有太多區(qū)別,但在分組、注解地方、嵌套驗(yàn)證等功能上有所不同,下面這篇文章主要給大家介紹了關(guān)于spring注解之@Valid和@Validated區(qū)分的相關(guān)資料,需要的朋友可以參考下

@Valid:

@Valid注解用于校驗(yàn),所屬包為:javax.validation.Valid。

① 首先需要在實(shí)體類的相應(yīng)字段上添加用于充當(dāng)校驗(yàn)條件的注解,如:@Min,如下代碼(age屬于Girl類中的屬性):

@Min(value = 18,message = "未成年禁止入內(nèi)")  
private Integer age;  

② 其次在controller層的方法的要校驗(yàn)的參數(shù)上添加@Valid注解,并且需要傳入BindingResult對(duì)象,用于獲取校驗(yàn)失敗情況下的反饋信息,如下代碼:

@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()用于獲取相應(yīng)字段上添加的message中的內(nèi)容,如:@Min注解中message屬性的內(nèi)容

@Validated:

@Valid是javax.validation里的。

@Validated是@Valid 的一次封裝,是Spring提供的校驗(yàn)機(jī)制使用。@Valid不提供分組功能

@Validated的特殊用法

1、分組

當(dāng)一個(gè)實(shí)體類需要多種驗(yàn)證方式時(shí),例:對(duì)于一個(gè)實(shí)體類的id來說,新增的時(shí)候是不需要的,對(duì)于更新時(shí)是必須的。

可以通過groups對(duì)驗(yàn)證進(jìn)行分組

分組接口類(通過向groups分配不同類的class對(duì)象,達(dá)到分組目的):

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

實(shí)體類:

package com.valid.pojo;  
import javax.validation.constraints.Size;  
import org.hibernate.validator.constraints.NotEmpty;  
import com.valid.interfaces.First;  
public class People {  
    //在First分組時(shí),判斷不能為空  
    @NotEmpty(groups={First.class})  
    private String id;  
    //name字段不為空,且長(zhǎng)度在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,默認(rèn)每次都要進(jìn)行驗(yàn)證

(2)對(duì)一個(gè)參數(shù)需要多種驗(yàn)證方式時(shí),也可通過分配不同的組達(dá)到目的。例:

@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")  
    //不需驗(yàn)證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")  
    //需要驗(yàn)證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屬性時(shí),默認(rèn)驗(yàn)證沒有分組的驗(yàn)證屬性,如該例子:People的name屬性。

@Validated沒有添加groups屬性時(shí),所有參數(shù)的驗(yàn)證類型都有分組(即本例中People的name的@NotEmpty、@Size都添加groups屬性),則不驗(yàn)證任何參數(shù)

2、組序列

默認(rèn)情況下,不同組別的約束驗(yàn)證是無序的,然而在某些情況下,約束驗(yàn)證的順序卻很重要。

例:

(1)第二個(gè)組中的約束驗(yàn)證依賴于一個(gè)穩(wěn)定狀態(tài)來運(yùn)行,而這個(gè)穩(wěn)定狀態(tài)是由第一個(gè)組來進(jìn)行驗(yàn)證的。

(2)某個(gè)組的驗(yàn)證比較耗時(shí),CPU 和內(nèi)存的使用率相對(duì)比較大,最優(yōu)的選擇是將其放在最后進(jìn)行驗(yàn)證。因此,在進(jìn)行組驗(yàn)證的時(shí)候尚需提供一種有序的驗(yàn)證方式,這就提出了組序列的概念。
一個(gè)組可以定義為其他組的序列,使用它進(jìn)行驗(yàn)證的時(shí)候必須符合該序列規(guī)定的順序。在使用組序列驗(yàn)證的時(shí)候,如果序列前邊的組驗(yàn)證失敗,則后面的組將不再給予驗(yàn)證。

分組接口類 (通過@GroupSequence注解對(duì)組進(jìn)行排序):

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 {  
}  

實(shí)體類:

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分組時(shí),判斷不能為空  
    @NotEmpty(groups={First.class})  
    private String id;  
      
    //name字段不為空,且長(zhǎng)度在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;  
    }  
}  

控制類:

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.Group;  
import com.valid.pojo.People;  
import com.valid.pojo.Person;  
@Controller  
public class FirstController {  
    @RequestMapping("/addPeople")  
    //不需驗(yàn)證ID  
    public @ResponseBody String addPeople(@Validated({Group.class}) People p,BindingResult result)  
    {  
        if(result.hasErrors())  
        {  
            return "0";  
        }  
        return "1";  
    }  
} 

3、驗(yàn)證多個(gè)對(duì)象

一個(gè)功能方法上處理多個(gè)模型對(duì)象時(shí),需添加多個(gè)驗(yàn)證結(jié)果對(duì)象

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";  
    }  
}  

補(bǔ)充:主要區(qū)別

在檢驗(yàn)Controller的入?yún)⑹欠穹弦?guī)范時(shí),使用@Validated或者@Valid在基本驗(yàn)證功能上沒有太多區(qū)別。但是在分組、注解地方、嵌套驗(yàn)證等功能上兩個(gè)有所不同:

 @Validated@Valid
分組提供分組功能,可在入?yún)Ⅱ?yàn)證時(shí),根據(jù)不同的分組采用不同的驗(yàn)證機(jī)制。無分組功能

可注解位置    

可以用在類型、方法和方法參數(shù)上。但是不能用在成員屬性上可以用在方法、構(gòu)造函數(shù)、方法參數(shù)和成員屬性上(兩者是否能用于成員屬性上直接影響能否提供嵌套驗(yàn)證的功能)
嵌套驗(yàn)證

用在方法入?yún)⑸蠠o法單獨(dú)提供嵌套驗(yàn)證功能。

不能用在成員屬性上。

也無法提供框架進(jìn)行嵌套驗(yàn)證。

能配合嵌套驗(yàn)證注解@Valid進(jìn)行嵌套驗(yàn)證。

用在方法入?yún)⑸蠠o法單獨(dú)提供嵌套驗(yàn)證功能。

能夠用在成員屬性上,提示驗(yàn)證框架進(jìn)行嵌套驗(yàn)證。

能配合嵌套驗(yàn)證注解@Valid進(jìn)行嵌套驗(yàn)證。

總結(jié)

到此這篇關(guān)于spring注解之@Valid和@Validated的區(qū)分總結(jié)的文章就介紹到這了,更多相關(guān)@Valid和@Validated區(qū)分內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論