今天在使用Validator框架数据验证的时候碰到了三个类似的注解,都是用来限制长度,但是用法上有区别: 1,@Size和@Length @Datapublic class LoginVo { @Length(min = 5, ma
今天在使用Validator框架数据验证的时候碰到了三个类似的注解,都是用来限制长度,但是用法上有区别:
@Datapublic class LoginVo { @Length(min = 5, max = 17, message = "userName长度须在[5,17]") // 可以为 null,若不为 null,则长度为 [5, 17] private String userName; // @Size不能验证Integer,适用于String @Size(min = 1, max = 3, message = "passWord长度须在[1,3]") private String password; @Size(min = 1,max = 5,message = "list的Size在[1,5]") // list 可以为 null,若不为 null,则长度为 [1, 5] private List list; @NotNull @Valid // 级联校验,该注解将会校验自定义类 private OrderItem detailInfo;}
@Size是一个Bean验证注释,用于验证关联的String具有的长度受最小值和最大值限制的值.
@Length是一个Hibernate特定的注释,与@Size具有相同的含义;
用@length限制长度为100,@length验证的应该为100个字符的长度,如99个汉字+2个数字,@length并不会报错;
但用@size限制长度为100,同样情况下则会报错,即超出限制长度
综上,@length限制长度为字符长度,@size限制长度为个数长度,@size为限制长度通用格式
@Entity@Datapublic class MyEntity { @Column(name = "MY_FIELD_1", length=13) private String myField1; @Column(name = "MY_FIELD_2") @Size(min = 13, max = 13) private String myField2; @Column(name = "MY_FIELD_3") @Length(min = 13, max = 13) private String myField3;}
同样的在实体类当中可以定义@Colunm注解当中设置length属性。这是一个JPA注释,并且length属性由模式生成工具用于设置关联的sql列长度,与DDL有关
来源地址:https://blog.csdn.net/weixin_46254692/article/details/128961716
--结束END--
本文标题: Spring Boot使用 Hibernate-Validator校验参数时的长度校验
本文链接: https://www.lsjlt.com/news/418972.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-04-03
2024-04-03
2024-04-01
2024-01-21
2024-01-21
2024-01-21
2024-01-21
2023-12-23
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0