美文网首页微服务架构
javax.validation JSR验证框架

javax.validation JSR验证框架

作者: 青丝如梦 | 来源:发表于2019-11-05 14:26 被阅读0次

原文地址:https://blog.csdn.net/wuseyukui/article/details/81164207

JSR-303 与 hibernate-validator

Spring3支持JSR-303验证框架,JSR-303 是Java EE 6 中的一项子规范,叫做BeanValidation,官方参考实现是hibernate-validator(与Hibernate ORM 没有关系),JSR 303 用于对Java Bean 中的字段的值进行验证。

hibernate-validator实现了JSR-303规范,并扩展了一些注解,提供了一套比较完善、便捷的验证实现方式。

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

spring-boot-starter-web已默认依赖hibernate-validator包,故无需重复添加 spring-boot-starter-validation 依赖。若想单独实现 Bean 验证,则只需单加入 spring-boot-starter-validation 依赖即可。
spring-boot-starter-web依赖关系:

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator</artifactId>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
        </dependency>
    </dependencies>

spring-boot-starter-validation依赖关系:

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.tomcat.embed</groupId>
            <artifactId>tomcat-embed-el</artifactId>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator</artifactId>
        </dependency>
    </dependencies>

校验bean(参数封装成对象)

POST接口 + @Valid + BindingResult 验证示例:

@Controller
@RequestMapping("/user")
public class UserController {

    /**
     * 创建用户
     * @requestBody可以将请求体中的JSON字符串绑定到相应的bean上
     * BindingResult是验证不通过的结果集合
     */
    @RequestMapping(value = "/create", method = RequestMethod.POST)
    @ResponseBody
    public String postUser(@RequestBody @Valid User user, BindingResult result) {
        if (result.hasErrors()) {
            for (ObjectError error : result.getAllErrors()) {
                System.out.println(error.getDefaultMessage());
            }
            return "error";
        }
        return "success";
    }
}

常用示例

User.java

@Data // Lombok注解,可以使我们不用再在代码里手动加get、set、toString、equals和hashCode等方法
public class User {

    @NotBlank(message = "用户名不能为空")
    private String name;

    @NotBlank(message = "年龄不能为空")
    @Range(min = 0, max = 120, message = "年龄只能从0-120岁")
    private String age;

    // 如果是空,则不校验,如果不为空,则校验
    @Pattern(regexp = "^[0-9]{4}-[0-9]{2}-[0-9]{2}$", message = "出生日期格式不正确")
    private String birthday;

}

示例2

import javax.validation.Configuration;
import javax.validation.ConstraintViolation;
import javax.validation.Validation;
import javax.validation.Validator;
import javax.validation.ValidatorFactory;

public class Test{
    private static final Validator VALIDATOR;

    //获得验证器实例
    static {
        Configuration<?> config = Validation.byDefaultProvider().configure();
        ValidatorFactory factory = config.buildValidatorFactory();
        VALIDATOR = factory.getValidator();
        factory.close();
    }

    public static void main(String []args){
        UserBo userBo = new UserBo(loginno, userName, operatorid, orgId, email);
        Set<ConstraintViolation<UserBo>> validate = VALIDATOR.validate(userBo);
        if (CollectionUtils.isNotEmpty(validate)) {
            StringBuilder stringBuilder = new StringBuilder();
            validate.forEach(item -> stringBuilder.append(item.getMessage()).append(","));
            throw new RuntimeException(stringBuilder.toString().substring(0, stringBuilder.length() - 1));
        }
    }
}

相关文章

网友评论

    本文标题:javax.validation JSR验证框架

    本文链接:https://www.haomeiwen.com/subject/gieulqtx.html