JSR303验证

什么是JSR303?

JSR303是Java为Bean数据合法性校验提供给的标准框架,已经包含在 JavaEE6.0中、
JSR303给Bean添加校验注解(类似 @NotNull @Max 等标准的注解),定义自己的message提示指定校验规则,并通过标准的验证接口对 Bean进行验证.JSR303属于后端验证
JS属于前端的脚本验证(只作用于客户端的浏览器中,可以被屏蔽)

为什么使用JSR303?

处理一段业务逻辑,首先要确保数据输入的正确性,所以需要先对数据进行检查,保证数据在语义上的正确性,再根据数据进行下一步的处理。
前端可以通过 js 程序校验数据是否合法,后端同样也需要进行校验。而后端最简单的实现就是直接在业务方法中对数据进行处理,但是不同的业务方法可能会出现同样的校验操作,这样就出现了数据的冗余。为了解决这个情况,JSR 303 出现了。
JSR 303 使用 Bean Validation,即在 Bean 上添加相应的注解,去实现数据校验。这样在执行业务方法前,都会根据注解对数据进行校验,从而减少自定义的校验逻辑,减少代码冗余。

添加相关依赖
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
<version>6.0.7.Final</version>
</dependency>

常用的注解:

@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(regex=,flag=)  被注释的元素必须符合指定的正则表达式

--------------------------------------------------------------------------------------
Hibernate Validator 附加的注解
@NotBlank(message =)   验证字符串非null,且长度必须大于0
@Email  被注释的元素必须是电子邮箱地址
@Length(min=,max=)  被注释的字符串的大小必须在指定的范围内
@NotEmpty   被注释的字符串的必须非空
@Range(min=,max=,message=)  被注释的元素必须在合适的范围内

@NotNull    被注释的元素必须不为 null    应用于八大基本数据类型
@NotBlank(message ="用户名不能为空!")   验证字符串非null,且长度必须大于0     应用于         String/引用
@NotEmpty   被注释的字符串的必须非空    应用于集合

注意!!!(Hibernate Validator是JSR303的一个参考实现,除了支持所有标准的校验注解外,另外Hibernate Validator还有JSR-380的实现

使用方式:

后端

在实体类的属性上加注解

@NotBlank 和 @NotNull注解中的属性message :就是你要向前端提示的验证信息。(就如上图所示的几个属性加的注解中的sessage都对应一个提示信息)

前端:

首先要在前端页面引入标签库:

然后通过取的名字在属性标签后面添加错误提示

fm:errors就是错误提示的标签然后通过属性path找到你在实体类中添加错误提示的属性名实现。

分组验证:

在实体类中添加分组验证接口:

public static interface ValidateGroups {
// 新增
public static interface Isnert {}
// 删除
public static interface Delete {}
// 修改
public static interface Update{}
}

然后通过注解@NotNull 和 @NotBlank注解中的属性groups来实现。

groups = {分组验证的接口组的接口名.分组验证的内部的接口.class}

这样子就能在不同的操作下提示不同的信息


版权声明:本文为m0_67143804原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。