自定义javax.validation校验结束时间大于等于开始时间

import javax.validation.Constraint;
import javax.validation.Payload;
import java.lang.annotation.*;

/**
 * @author cr 2020-04-21 校验结束时间大于等于开始时间
 */
@Target({ElementType.TYPE, ElementType.FIELD, ElementType.METHOD, ElementType.PARAMETER, ElementType.ANNOTATION_TYPE,
        ElementType.TYPE_USE})
@Retention(RetentionPolicy.RUNTIME)
@Constraint(validatedBy = CheckTimeIntervalValidation.class)
@Documented
@Repeatable(CheckTimeInterval.List.class)
public @interface CheckTimeInterval {
    
    String beginTime() default "from";
    
    String endTime() default "to";
    
    String message() default "{org.hibernate.validator.referneceguide.chapter06.CheckCase.message}";
    
    Class<?>[] groups() default {};
    
    Class<? extends Payload>[] payload() default {};
    
    @Target({ElementType.TYPE, ElementType.FIELD, ElementType.METHOD, ElementType.PARAMETER,
            ElementType.ANNOTATION_TYPE})
    @Retention(RetentionPolicy.RUNTIME)
    @Documented
    @interface List {
        
        CheckTimeInterval[] value();
    }
}

 

import com.dahuatech.creditcloud.util.DateUtil;
import com.dahuatech.creditcloud.util.StrUtils;
import org.springframework.beans.BeanWrapper;
import org.springframework.beans.BeanWrapperImpl;

import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import java.util.Date;

/**
 * @author cr 2020-04-21 校验结束时间大于等于开始时间
 */
public class CheckTimeIntervalValidation implements ConstraintValidator<CheckTimeInterval, Object> {
    
    private String beginTime;
    
    private String endTime;
    
    @Override
    public void initialize(CheckTimeInterval constraintAnnotation) {
        this.beginTime = constraintAnnotation.beginTime();
        this.endTime = constraintAnnotation.endTime();
    }
    
    @Override
    public boolean isValid(Object value, ConstraintValidatorContext context) {
        BeanWrapper beanWrapper = new BeanWrapperImpl(value);
        String begin = StrUtils.convertString(beanWrapper.getPropertyValue(beginTime));
        String end = StrUtils.convertString(beanWrapper.getPropertyValue(endTime));
        if (begin.isEmpty() || end.isEmpty()) {
            return true;
        }
        Date d1 = DateUtil.dateParse(begin);
        Date d2 = DateUtil.dateParse(end);
        if (null == d1 || null == d2) {
            return false;
        }
        int result = d2.compareTo(d1);
        return result >= 0;
    }
}
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于自定义 javax.validation 的实现,你可以按照以下步骤进行操作: 1. 创建自定义的 Constraint 注解:首先,你需要创建一个自定义的注解,用于定义验证规则。你可以使用注解元素来指定验证的条件和错误消息。 ```java @Target({ElementType.FIELD}) @Retention(RetentionPolicy.RUNTIME) @Constraint(validatedBy = CustomValidator.class) public @interface CustomConstraint { String message() default "Invalid value"; Class<?>[] groups() default {}; Class<? extends Payload>[] payload() default {}; } ``` 2. 创建自定义的验证器:接下来,你需要创建一个实现 `ConstraintValidator` 接口的自定义验证器。在验证器中,你可以编逻辑来验证注解标记的字段。 ```java public class CustomValidator implements ConstraintValidator<CustomConstraint, String> { @Override public void initialize(CustomConstraint constraintAnnotation) { // 初始化操作 } @Override public boolean isValid(String value, ConstraintValidatorContext context) { // 编验证逻辑 // 返回 true 表示验证通过,返回 false 表示验证失败 } } ``` 3. 在实体类中使用自定义注解:将自定义注解应用到需要验证的字段上。 ```java public class MyEntity { @CustomConstraint private String myField; // 其他属性和方法 } ``` 4. 注册验证器:在你的应用程序配置中注册自定义的验证器,以便在验证过程中被使用。 ```java @Configuration public class ValidationConfig implements ValidatorConfigurer { @Override public void configureValidatorFactory(ValidatorFactory factory) { ConstraintValidatorFactory constraintValidatorFactory = factory.getConstraintValidatorFactory(); // 注册自定义的验证器 ((HibernateValidatorFactory) factory).addConstraintValidatorFactory(constraintValidatorFactory); } } ``` 这样,当你使用 `javax.validation` 进行验证时,自定义的验证器将会被调用,并进行自定义的验证逻辑。 请注意,这只是一个简单的示例,你可以根据你的具体需求进行更复杂的实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值