转载一下
@GroupSequence自定义验证顺序
https://blog.csdn.net/chepeng3577/article/details/100719210
但是还不够完整,springboot中
1.依赖选用
<dependency>
<groupId>org.hibernate.validator</groupId>
<artifactId>hibernate-validator</artifactId>
</dependency>
2.定义类组,决定顺序
@GroupSequence({ValidateGroupA.class,ValidateGroupB.class,ValidateGroupC.class})
public interface ValidateGroup {
}
A,B,C 里面没有任何注解和接口,纯粹式作为一个顺序,来标记一下而已。
@RequestMapping("/testValidate")
public String testValidate(@RequestBody @Validated({ValidateGroup.class}) User user){
System.out.println(user);
return "sss";
}
针对user实体类。
@Data
public class User {
@NotNull(message = "{id.empty}", groups = { ValidateGroupA.class })
private int id;
@NotNull(message = "{name.empty}", groups = { ValidateGroupA.class })
@Length(min=1,max = 20,message = "长度不在1-20之间",groups ={ ValidateGroupB.class } )
@Pattern(regexp = "^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\\.[a-zA-Z0-9_-]+)+$",message = "不符合邮箱格式",groups = {ValidateGroupC.class})
private String username;
}
主要式针对了username 来逐步的验证,首先验证不为null,第二步验证长度在 1-20之间,最后载验证符不符合某种格式。
可以很好的避免每次都来验证。