博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Springmvc的数据验证---注解式
阅读量:3939 次
发布时间:2019-05-23

本文共 3955 字,大约阅读时间需要 13 分钟。

JSR-303 Bean Validation

JSR 是Java Specification Requests 的缩写,是指向 JCP(Java Community Process) 提出新增一个标准化技术规范的正式请求。

任何人都可以提交 JSR,以向 Java 平台增添新的 API 和服务,已审核通过的规范涉及 Java 各个领域,有兴趣可以了解一下。

Bean Validation 是一个运行时的数据验证框架,为 JavaBean 验证定义了相应的元数据模型和 API。

默认的元数据是 Java Annotations,当然也可以使用 XML 可以对已存在的元数据信息进行覆盖和扩展。

在应用中通过使用 Bean Validation 或是你自己定义的 constraint,例如 @NotNull, @Max, @ZipCode, 就可以确保数据模型的正确性。

constraint 可以注解到字段,getter 方法,类或者接口上面。对于一些特定的需求,用户可以很容易的开发定制化的 constraint。

Hibernate Validator 做为 Bean Validation 的参考实现 .提供了 JSR 303 规范中所有内置 constraint 的实现,除此之外还有一些附加的 constraint。

Sun validation-api.jar 中定义的规范 constraint

Spring MVC 服务端验证实践

2.1客户端表单验证,代码写在js上,容易被攻击,服务端表单验证
2.2导入依赖(尽量与sping 版本一样)

org.hibernate
hibernate-validator
5.0.2.Final

2.3参考配置

验证注解 验证的数据类型 说明

AssertFalsefalse Boolean,boolean 验证注解的元素值是true
AssertTrue Boolean,boolean 验证注解的元素值是true
NotNull 任意类型 验证注解的元素值不是null
Null 任意类型 验证注解的元素值是null
Min(value=值) BigDecimal,BigInteger, byte,short, int, long,等任何Number或CharSequence(存储的是数字)子类型 验证注解的元素值大于等于@Min指定的value
Max(value=值) 和@Min要求一样 验证注解的元素值小于等于@Max指定的value
@DecimalMin(value=值) 和@Min要求一样 验证注解的元素值大于等于@ DecimalMin指定的value值
@DecimalMax(value=值) 和@Min要求一样 验证注解的元素值小于等于@ DecimalMax指定的value值
@Digits(integer=整数位数, fraction=小数位数) 和@Min要求一样 验证注解的元素值的整数位数和小数位数上
@Size(min=下限, max=上限) 字符串、Collection、Map、数组等 验证注解的元素值的在min和max(包含)指定区间之内,如字符长度、集合大小
@Past java.util.Date,java.util.Calendar;Joda Time类库的日期类型 验证注解的元素值(日期类型)比当前时间
@Future 与@Past要求一样 验证注解的元素值(日期类型)比当前时间晚
@NotBlank CharSequence子类型 验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的首位空格
@Length(min=下限, max=上限) CharSequence子类型 验证注解的元素值长度在min和max区间内
@NotEmpty CharSequence子类型、Collection、Map、数组 验证注解的元素值不为null且不为空(字符串长度不为0、集合大小不为0)
@Range(min=最小值, max=最大值) BigDecimal,BigInteger,CharSequence, byte, short, int, long等原子类型和包装类型 验证注解的元素值在最小值和最大值之间
@Email(regexp=正则表达式,flag=标志的模式) CharSequence子类型(如String) 验证注解的元素值是Email,也可以通过regexp和flag指定自定义的email格式
@Pattern(regexp=正则表达式,flag=标志的模式) String,任何CharSequence的子类型 验证注解的元素值与指定的正则表达式匹配
@Valid 任何非原子类型 指定递归验证关联的对象;如用户对象中有个地址对象属性,如果想在验证用户对象时一起验证地址对象的话,在地址对象上加@Valid注解即可级联验证
2.4代码参考

package com.zking.ssm.model;

import lombok.ToString;

import org.hibernate.validator.constraints.NotBlank;
import org.hibernate.validator.constraints.NotEmpty;

import javax.validation.constraints.Digits;

@ToString

public class Book {
@NotBlank(message = “书记唯一标识列不能为空”)
private Integer bid;

@NotEmpty(message = "书籍名称不能相同")private String bname;@Digits(integer = 500,fraction = 2)private Float price;public Book(Integer bid, String bname, Float price) {    this.bid = bid;    this.bname = bname;    this.price = price;}public Book() {    super();}public Integer getBid() {    return bid;}public void setBid(Integer bid) {    this.bid = bid;}public String getBname() {    return bname;}public void setBname(String bname) {    this.bname = bname;}public Float getPrice() {    return price;}public void setPrice(Float price) {    this.price = price;}

}

package com.zking.ssm.model;

import lombok.ToString;

import org.hibernate.validator.constraints.NotBlank;
import org.hibernate.validator.constraints.NotEmpty;

import javax.validation.constraints.DecimalMin;

import javax.validation.constraints.Digits;

@ToString

public class Book {
@NotBlank(message = “书记唯一标识列不能为空”)
private Integer bid;

@NotEmpty(message = "书籍名称不能相同")private String bname;@DecimalMin(value = "1",message = "至少不能小于1")@Digits(integer = 500,fraction = 2,message = "最大500,精确到小数点后2位")private Float price;public Book(Integer bid, String bname, Float price) {    this.bid = bid;    this.bname = bname;    this.price = price;}public Book() {    super();}public Integer getBid() {    return bid;}public void setBid(Integer bid) {    this.bid = bid;}public String getBname() {    return bname;}public void setBname(String bname) {    this.bname = bname;}public Float getPrice() {    return price;}public void setPrice(Float price) {    this.price = price;}

}

转载地址:http://omuwi.baihongyu.com/

你可能感兴趣的文章
解决POJO的属性首字母为大写,但是赋值不了的问题
查看>>
服务器运维整理(笔记)
查看>>
redis分布式锁在MySQL事务代码中使用,没控制好并发原因
查看>>
centos7中的网卡一致性命名规则、网卡重命名方法
查看>>
能切换环境的python
查看>>
Tmux 使用教程
查看>>
DLINK-DSN1100的安装使用记录
查看>>
openssl的学习
查看>>
watchguard ssl100恢复出厂化设置
查看>>
CentOS 一键安装Cacti 1.2.3脚本
查看>>
CentOS 7系统上制作Clonezilla(再生龙)启动U盘并克隆双系统
查看>>
fail2ban的使用-控制连接数
查看>>
btkill-连接数控制
查看>>
NAT+www的发布
查看>>
dhcp.conf
查看>>
关于win10的升级
查看>>
cacti突然不显示流量
查看>>
发现一个好工具记录一下,U盘启动ISO文件。
查看>>
centos7下配置网卡以及查询网卡UUID
查看>>
适用于旧计算机的10款最佳轻量级Linux发行版
查看>>