原文:http://blog.csdn.net/littleskey/article/details/52224352
@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;
- }
- }
- 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")
- //不需驗證ID
- public @ResponseBody String addPeople(@Validated({Group.class}) People p,BindingResult result)
- {
- if(result.hasErrors())
- {
- return "0";
- }
- return "1";
- }
- }
一個功能方法上處理多個模型對象時,需添加多個驗證結果對象
- 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";
- }
- }