依赖的jar包导入
@Valid注解用于校验,所属包为:javax.validation.Valid。
(1)、首先需要在实体类的相应字段上添加用于充当校验条件的注解,如:@NotEmpty如下代码(User类中的属性):
@Entity
@Table(name="t_user")
public class User {
@Id
@GeneratedValue
private Integer id; // 编号
@NotEmpty(message="请输入用户名!")
@Column(length=50)
private String userName; // 用户名
@NotEmpty(message="请输入密码!")
@Column(length=50)
private String password; // 密码
@Column(length=50)
private String trueName; // 真实姓名
@Column(length=1000)
private String remarks; // 备注
(2)、其次在controller层的方法的要校验的参数上添加@Valid注解,并且需要传入BindingResult对象,用于获取校验失败情况下的反馈信息,如下代码:
/**
* 用户登录判断
* @param user
* @param bindingResult
* @param session
* @return
*/
@ResponseBody
@RequestMapping("/login")
public Map
Map
if(bindingResult.hasErrors()){
map.put("success", false);
map.put("errorInfo", bindingResult.getFieldError().getDefaultMessage());
return map;
}
}
bindingResult.getFieldError.getDefaultMessage()用于获取相应字段上添加的message中的内容,如:@NotEmpty(message="请输入用户名!")注解中message属性的内容
更多的用法如下:
限制说明@Null限制只能为null@NotNull限制必须不为null@AssertFalse限制必须为false@AssertTrue限制必须为true@DecimalMax(value)限制必须为一个不大于指定值的数字@DecimalMin(value)限制必须为一个不小于指定值的数字@Digits(integer,fraction)限制必须为一个小数,且整数部分的位数不能超过integer,小数部分的位数不能超过fraction@Future限制必须是一个将来的日期@Max(value)限制必须为一个不大于指定值的数字@Min(value)限制必须为一个不小于指定值的数字@Past限制必须是一个过去的日期@Pattern(value)限制必须符合指定的正则表达式@Size(max,min)限制字符长度必须在min到max之间@Past验证注解的元素值(日期类型)比当前时间早@NotEmpty验证注解的元素值不为null且不为空(字符串长度不为0、集合大小不为0)@NotBlank验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格@Email验证注解的元素值是Email,也可以通过正则表达式和flag指定自定义的email格式