validation-api分组校验工具类

 主要是根据业务场景需求对参数进行校验,不单单是Rest层的校验,也可以作为普通方法参数校验。

引入依赖
        <dependency>
            <groupId>javax.validation</groupId>
            <artifactId>validation-api</artifactId>
            <version>1.1.0.Final</version>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator</artifactId>
            <version>5.2.4.Final</version>
        </dependency>
 

工具类:

public class ValidateUtil {

    public static Validator validator;
    private static ValidatorFactory factory;

    static {
        Locale.setDefault(new Locale("zh", "CN"));
        factory = Validation.buildDefaultValidatorFactory();
        validator = factory.getValidator();
    }

  
    public static <T> String paramCheckReturnStrMsg(T bean, Class<?>... groups) {
        if (bean == null) {
            return null;
        }
        Set<ConstraintViolation<T>> validateSet = validator.validate(bean, groups);
        StringBuilder stringBuilder = new StringBuilder();
        for (ConstraintViolation<T> constraintViolation : validateSet) {
            stringBuilder.append(constraintViolation.getMessage()).append(",");
        }
        if (stringBuilder.length() == 0) {
            return null;
        }
        return stringBuilder.toString().substring(0, stringBuilder.length() - 1);
    }
}

测试VO

public class User {

    // 标记接口
    public interface NameNotBlank{};

    private  int age;

    @NotBlank(message = "姓名不能为空",groups = NameNotBlank.class )
    private  String  name;

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public User(int age, String name) {
        this.age = age;
        this.name = name;
    }
}

测试方法:

@RestController
public class TestRe {
    @RequestMapping("/test")
    public String get(@RequestBody User user){     
        String str = ValidateUtil.paramCheckReturnStrMsg(user,User.NameNotBlank.class);
        if(null != str ){
            System.out.println("参数异常情况:"+str);
        }else{
            System.out.println("参数正常");
        } 
       return str;
    }
}

@NotNull 和 @NotEmpty  和@NotBlank 区别

@NotEmpty 用在集合类上面
@NotBlank 用在String上面
@NotNull    用在基本类型上

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Hibernate Validator 是一个基于 JSR 380 规范实现的校验框架,它提供了一系列的注解和 API,方便我们对 Java 对象进行校验。下面给出一个 Hibernate Validator 校验工具类的示例: ```java public class ValidationUtils { private static Validator validator = Validation.buildDefaultValidatorFactory().getValidator(); /** * 校验对象 * @param object校验对象 * @param groups 待校验的组 * @throws ValidationException 校验不通过,则报ValidationException异常 */ public static void validateEntity(Object object, Class<?>... groups) throws ValidationException { Set<ConstraintViolation<Object>> constraintViolations = validator.validate(object, groups); if (!constraintViolations.isEmpty()) { StringBuilder msg = new StringBuilder(); for (ConstraintViolation<Object> constraintViolation : constraintViolations) { msg.append(constraintViolation.getMessage()).append(";"); } throw new ValidationException(msg.toString()); } } } ``` 上述代码定义了一个名为 ValidationUtils 的工具类,其中包含了一个名为 validateEntity 的静态方法。该方法接收两个参数,其中 object 表示待校验的对象,groups 表示校验分组。方法内部使用 Hibernate ValidatorAPI 进行校验,并将校验结果保存在 constraintViolations 集合中。如果集合不为空,则表示校验不通过,将所有错误消息拼接起来,并抛出 ValidationException 异常。如果集合为空,则表示校验通过,方法直接返回。 可以看出,使用 Hibernate Validator 编写校验工具类非常简单,只需要创建一个 Validator 对象并调用其 validate 方法即可。对于校验不通过的情况,可以将所有错误消息拼接起来,或者只取第一个错误消息作为异常消息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值