众多周知 光进行前端验证,可能遭到恶意人为的修改表单发送欺骗请求
所以在SpingBoot中 使用Hibernate-Validator
注解
基本提供了常用的校验注解,如果不满足业务,可以通过@pattern自行定义正则表达式。
@Null 被注释的元素必须为null
@NotNull 被注释的元素不能为null
@AssertTrue 被注释的元素必须为true
@AssertFalse 被注释的元素必须为false
@Min(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@Max(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@DecimalMin(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
@DecimalMax(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
@Size(max,min) 被注释的元素的大小必须在指定的范围内。
@Digits(integer,fraction) 被注释的元素必须是一个数字,其值必须在可接受的范围内
@Past 被注释的元素必须是一个过去的日期
@Future 被注释的元素必须是一个将来的日期
@Pattern(value) 被注释的元素必须符合指定的正则表达式。
@Email 被注释的元素必须是电子邮件地址
@Length 被注释的字符串的大小必须在指定的范围内
@NotEmpty 被注释的字符串必须非空
@Range 被注释的元素必须在合适的范围内
案例
@Data
@Entity
@Table(name = "sys_user")
public class SysUser implements Serializable{
/**
* 用户id
*/
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "user_id", nullable = false, length = 20)
private Long userId;
/**
* 用户名
*/
@NotNull
@Column(name = "username", nullable = false, length = 50)
private String username;
/**
* 密码
*/
@Size(min = 6, max = 25, message = "密码长度要求6到25之间")
@Column(name = "password", nullable = false, length = 50)
private String password;
/**
* 姓名(昵称)
*/
@NotNull
@Column(name = "nickname", length = 50)
private String nickname;
/**
* 邮箱
*/
@Email(message="邮箱格式不正确")
@Column(name = "email", length = 100)
private String email;
/**
* 手机号
*/
@Pattern(regexp="^((13[0-9])|(14[5|7])|(15([0-3]|[5-9]))|(17[013678])|(18[0,5-9]))\\d{8}$",message="手机格式不正确")
@Column(name = "mobile", length = 100)
private String mobile;
/**
* 状态 0:禁用,1:正常
*/
@Column(name = "status", length = 4)
private Short status;
/**
* 备注
*/
@Column(name = "remark", length = 500)
private String remark;
/**
* 创建用户id
*/
@Column(name = "user_id_create")
private Long userIdCreate;
/**
* 创建时间
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
@Column(name = "gmt_create")
private Timestamp gmtCreate;
/**
* 修改时间
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
@Column(name = "gmt_modified")
private Timestamp gmtModified;
}
以后就再也不用if else了