Spring MVC @Validated的使用

原文:http://blog.csdn.net/littleskey/article/details/52224352


@Valid是javax.validation裏的。

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


@Validated的特殊用法

1、分組

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

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

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

[html] view plain copy
  1. package com.valid.interfaces;  
  2.   
  3. public interface First {  
  4.   
  5. }  

實體類:

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

注:

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

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

[html] view plain copy
  1. @NotEmpty(groups={First.class})  
  2. @Size(min=3,max=8,groups={Second.class})  
  3. private String name;  

控制類:

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

注:

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

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

2、組序列

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

例:

(1)第二個組中的約束驗證依賴於一個穩定狀態來運行,而這個穩定狀態是由第一個組來進行驗證的。

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

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

[html] view plain copy
  1. package com.valid.interfaces;  
  2.   
  3. public interface First {  
  4.   
  5. }  
[html] view plain copy
  1. package com.valid.interfaces;  
  2.   
  3. public interface Second {  
  4.   
  5. }  

[html] view plain copy
  1. package com.valid.interfaces;  
  2.   
  3. import javax.validation.GroupSequence;  
  4.   
  5. @GroupSequence({First.class,Second.class})  
  6. public interface Group {  
  7.   
  8. }  
實體類:

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

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

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

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



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章