SpringBoot中@Pattern注解对时间格式校验方式
目录
- SpringBoot @Pattern注解对时间格式校验
- 1.需求背景
- 2.实现案例
- @Pattern的用法
- 下面是常用的正则表达式
SpringBoot @Pattern注解对时间格式校验
1.需求背景
有一个需求,在前端传过来的时间格式的字符串进行校验,是否符合"yyyy-MM-dd HH:mm:ss",在SpringBoot中当然可以用@Datetimeformat注解来进行验证,但字段的属性得用Date类型,由于我的项目中该字段用了String类型,需要对类型进行转换不太符合要求,所有用到了@Pattern注解。
在实体类的字段名上添加@Pattern注解,有个属性regexp,该属性的值就是正则表达式。
"yyyy-MM-dd HH:mm:ss"的正则表达式如下:
"^((([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]{1}|[0-9]{1}[1-9][0-9]{2}|[1-9][0-9]{3})-(((0[13578]|1[02])-(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)-(0[1-9]|[12][0-9]|30))|(02-(0[1-9]|[1][0-9]|2[0-8]))))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))-02-29))\\s+([0-1]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$"
我们还需用到@Validated注解,该注解使用在controller层的方法参数中,只有使用该注解,@pattern中的时间格式校验才起作用,这一点尤其重要。
2.实现案例
entity:
//删除时间 @Pattern(regexp = "^((([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]{1}|[0-9]{1}[1-9][0-9]{2}|[1-9][0-9]{3})-(((0[13578]|1[02])-(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)-(0[1-9]|[12][0-9]|30))|(02-(0[1-9]|[1][0-9]|2[0-8]))))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))-02-29))\\s+([0-1]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$") private String deletedAt;
//删除时间 @Pattern(regexp = "^((([0-9]{3}[1-9]|[0-9]{2}[1-9][0-9]{1}|[0-9]{1}[1-9][0-9]{2}|[1-9][0-9]{3})-(((0[13578]|1[02])-(0[1-9]|[12][0-9]|3[01]))|((0[469]|11)-(0[1-9]|[12][0-9]|30))|(02-(0[1-9]|[1][0-9]|2[0-8]))))|((([0-9]{2})(0[48]|[2468][048]|[13579][26])|((0[48]|[2468][048]|[3579][26])00))-02-29))\\s+([0-1]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$") private String deletedAt;
controller:
/** * 添加设备类别 */ @ApiOperation(value = "添加设备类别",notes="传入参数是category对象") @PostMapping("/category") public int addCategory(@Validated Category category){ return iCategory.addCategory(category); }
测试结果:
当输入的时间为2020-08-26或2020/08/26 11:22:33,时间格式不符合"yyyy-MM-dd HH:mm:ss",就会出现报错,如下所示:
只有输入正确格式的数据,才能插入成功:
@Pattern的用法
把这个注解加在entity的参数上,可以选择分类也可以默认;
关于注解中需要传的参数:一般默认就填入正则表达式即可,但是java中字符串需要转义,这个需要注意一下。
@Pattern(regexp = "\\w+$") private String userName;
在user传参或者controller层中的添加@Validated注解进行调用
举个栗子:
public void addUser(@Validated User user){...}
下面是常用的正则表达式
- 匹配首尾空格的正则表达式:(^\s*)|(\s*$)
- 整数或者小数:^[0-9]+\.{0,1}[0-9]{0,2}$
- 只能输入数字:"^[0-9]*$"。
- 只能输入n位的数字:"^\d{n}$"。
- 只能输入至少n位的数字:"^\d{n,}$"。
- 只能输入m~n位的数字:。"^\d{m,n}$"
- 只能输入零和非零开头的数字:"^(0|[1-9][0-9]*)$"。
- 只能输入有两位小数的正实数:"^[0-9]+(.[0-9]{2})?$"。
- 只能输入有1~3位小数的正实数:"^[0-9]+(.[0-9]{1,3})?$"。
- 只能输入非零的正整数:"^\+?[1-9][0-9]*$"。
- 只能输入非零的负整数:"^\-[1-9][]0-9"*$。
- 只能输入长度为3的字符:"^.{3}$"。
- 只能输入由26个英文字母组成的字符串:"^[A-Za-z]+$"。
- 只能输入由26个大写英文字母组成的字符串:"^[A-Z]+$"。
- 只能输入由26个小写英文字母组成的字符串:"^[a-z]+$"。
- 只能输入由数字和26个英文字母组成的字符串:"^[A-Za-z0-9]+$"。
- 只能输入由数字、26个英文字母或者下划线组成的字符串:"^\w+$"。
- 验证用户密码:"^[a-zA-Z]\w{5,17}$"正确格式为:以字母开头,长度在6~18之间,只能包含字符、数字和下划线。
- 验证是否含有^%&',;=?$\"等字符:"[^%&',;=?$\x22]+"。
- 只能输入汉字:"^[\u4e00-\u9fa5]{0,}$"
- 验证Email地址:"^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$"。
- 验证InternetURL:"^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$"。
- 验证电话号码:"^(\(\d{3,4}-)|\d{3.4}-)?\d{7,8}$"正确格式为:"XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX"。
- 验证身份证号(15位或18位数字):"^\d{15}|\d{18}$"。
- 验证一年的12个月:"^(0?[1-9]|1[0-2])$"正确格式为:"01"~"09"和"1"~"12"。
- 验证一个月的31天:"^((0?[1-9])|((1|2)[0-9])|30|31)$"正确格式为;"01"~"09"和"1"~"31"。
- 匹配中文字符的正则表达式: [\u4e00-\u9fa5]
- 匹配双字节字符(包括汉字在内):[^\x00-\xff]
- 应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
- String.prototype.len=function(){return this.replace(/[^\x00-\xff]/g,"aa").length;}
- 匹配空行的正则表达式:\n[\s| ]*\r
- 匹配html标签的正则表达式:<(.*)>(.*)<\/(.*)>|<(.*)\/>
- 中文字母数字下划线:^[a-zA-Z0-9_\u4e00-\u9fa5]*$
以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。