天天看點

@Valid和@Validated的總結區分

https://blog.csdn.net/gaojp008/article/details/80583301

@Valid:

@Valid注解用于校驗,所屬包為:javax.validation.Valid。

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

  1. @Min(value = ,message = "未成年禁止入内")
  2. private Integer age;

② 其次在controller層的方法的要校驗的參數上添加@Valid注解,并且需要傳入BindingResult對象,用于擷取校驗失敗情況下的回報資訊,如下代碼:

  1. @PostMapping( "/girls")
  2. public Girl addGirl(@Valid Girl girl, BindingResult bindingResult) {
  3. if(bindingResult.hasErrors()){
  4. System.out.println(bindingResult.getFieldError().getDefaultMessage());
  5. return null;
  6. }
  7. return girlResposity.save(girl);
  8. }

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

@Validated:

@Valid是javax.validation裡的。

@Validated是@Valid 的一次封裝,是Spring提供的校驗機制使用。@Valid不提供分組功能

@Validated的特殊用法

1、分組

當一個實體類需要多種驗證方式時,例:對于一個實體類的id來說,新增的時候是不需要的,對于更新時是必須的。

可以通過groups對驗證進行分組

分組接口類(通過向groups配置設定不同類的class對象,達到分組目的):

  1. package com.valid.interfaces;
  2. public interface First {
  3. }

實體類:

  1. package com.valid.pojo;
  2. import javax.validation.constraints.Size;
  3. import org.hibernate.validator.constraints.NotEmpty;
  4. import com.valid.interfaces.First;
  5. public class People {
  6. //在First分組時,判斷不能為空
  7. @NotEmpty(groups={First.class})
  8. private String id;
  9. //name字段不為空,且長度在3-8之間
  10. @NotEmpty
  11. @Size(min= ,max= )
  12. private String name;
  13. public String getName() {
  14. return name;
  15. }
  16. public void setName(String name) {
  17. this.name = name;
  18. }
  19. public String getId() {
  20. return id;
  21. }
  22. public void setId(String id) {
  23. this.id = id;
  24. }
  25. }

注:

(1)不配置設定groups,預設每次都要進行驗證

(2)對一個參數需要多種驗證方式時,也可通過配置設定不同的組達到目的。例:

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

控制類:

  1. package com.valid.controller;
  2. import org.springframework.stereotype.Controller;
  3. import org.springframework.validation.BindingResult;
  4. import org.springframework.validation.annotation.Validated;
  5. import org.springframework.web.bind.annotation.RequestMapping;
  6. import org.springframework.web.bind.annotation.ResponseBody;
  7. import com.valid.interfaces.First;
  8. import com.valid.pojo.People;
  9. @Controller
  10. public class FirstController {
  11. @RequestMapping( "/addPeople")
  12. //不需驗證ID
  13. public @ResponseBody String addPeople(@Validated People p,BindingResult result)
  14. {
  15. System.out.println( "people's ID:" + p.getId());
  16. if(result.hasErrors())
  17. {
  18. return "0";
  19. }
  20. return "1";
  21. }
  22. @RequestMapping( "/updatePeople")
  23. //需要驗證ID
  24. public @ResponseBody String updatePeople(@Validated({First.class}) People p,BindingResult result)
  25. {
  26. System.out.println( "people's ID:" + p.getId());
  27. if(result.hasErrors())
  28. {
  29. return "0";
  30. }
  31. return "1";
  32. }
  33. }

注:

@Validated沒有添加groups屬性時,預設驗證沒有分組的驗證屬性,如該例子:People的name屬性。

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

2、組序列

預設情況下,不同組别的限制驗證是無序的,然而在某些情況下,限制驗證的順序卻很重要。

例:

(1)第二個組中的限制驗證依賴于一個穩定狀态來運作,而這個穩定狀态是由第一個組來進行驗證的。

(2)某個組的驗證比較耗時,CPU 和記憶體的使用率相對比較大,最優的選擇是将其放在最後進行驗證。是以,在進行組驗證的時候尚需提供一種有序的驗證方式,這就提出了組序列的概念。

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

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

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

實體類:

  1. package com.valid.pojo;
  2. import javax.validation.constraints.Size;
  3. import org.hibernate.validator.constraints.NotEmpty;
  4. import com.valid.interfaces.First;
  5. import com.valid.interfaces.Second;
  6. public class People {
  7. //在First分組時,判斷不能為空
  8. @NotEmpty(groups={First.class})
  9. private String id;
  10. //name字段不為空,且長度在3-8之間
  11. @NotEmpty(groups={First.class})
  12. @Size(min= ,max= ,groups={Second.class})
  13. private String name;
  14. public String getName() {
  15. return name;
  16. }
  17. public void setName(String name) {
  18. this.name = name;
  19. }
  20. public String getId() {
  21. return id;
  22. }
  23. public void setId(String id) {
  24. this.id = id;
  25. }
  26. }

控制類:

  1. package com.valid.controller;
  2. import org.springframework.stereotype.Controller;
  3. import org.springframework.validation.BindingResult;
  4. import org.springframework.validation.annotation.Validated;
  5. import org.springframework.web.bind.annotation.RequestMapping;
  6. import org.springframework.web.bind.annotation.ResponseBody;
  7. import com.valid.interfaces.Group;
  8. import com.valid.pojo.People;
  9. import com.valid.pojo.Person;
  10. @Controller
  11. public class FirstController {
  12. @RequestMapping( "/addPeople")
  13. //不需驗證ID
  14. public @ResponseBody String addPeople(@Validated({Group.class}) People p,BindingResult result)
  15. {
  16. if(result.hasErrors())
  17. {
  18. return "0";
  19. }
  20. return "1";
  21. }
  22. }

3、驗證多個對象

一個功能方法上處理多個模型對象時,需添加多個驗證結果對象

  1. package com.valid.controller;
  2. import org.springframework.stereotype.Controller;
  3. import org.springframework.validation.BindingResult;
  4. import org.springframework.validation.annotation.Validated;
  5. import org.springframework.web.bind.annotation.RequestMapping;
  6. import org.springframework.web.bind.annotation.ResponseBody;
  7. import com.valid.pojo.People;
  8. import com.valid.pojo.Person;
  9. @Controller
  10. public class FirstController {
  11. @RequestMapping( "/addPeople")
  12. public @ResponseBody String addPeople(@Validated People p,BindingResult result,@Validated Person p2,BindingResult result2)
  13. {
  14. if(result.hasErrors())
  15. {
  16. return "0";
  17. }
  18. if(result2.hasErrors())
  19. {
  20. return "-1";
  21. }
  22. return "1";
  23. }
  24. }

繼續閱讀