关于java的注解在此就不赘述了。如有疑惑的小伙伴,请自行“度娘”。下面直接上代码
1、注解类
package com.jwssw.annotation;
import javax.validation.Constraint;
import javax.validation.Payload;
import java.lang.annotation.*;
/**
* 类描述:日期类型注解
*
* @author 鲁浩鹏 Lu Haopeng
* @version 1.0
* @email <a href="mailTo:luhaopeng2005@126.com">Lu Haopeng</a>
* @date 2022/2/13 14:15
* @since JDK 8
*/
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
@Constraint(validatedBy = {DateTimeValidator.class})
public @interface DateTimeStr {
/**
* 日期格式,默认为空,可以是任何类型的日期格式
*/
String format() default "";
/**
* 提示消息
*/
String message() default "日期格式不正确";
/**
* 分组
*/
Class<?>[] groups() default {};
/**
* 有效载荷集合
*/
Class<? extends Payload>[] payload() default {};
}
2、注解验证器
package com.jwssw.annotation;
import cn.hutool.core.date.DateUtil;
import cn.hutool.core.util.StrUtil;
import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
/**
* 类描述:日期类型注解
*
* @author 鲁浩鹏 Lu Haopeng
* @version 1.0
* @email <a href="mailTo:luhaopeng2005@126.com">Lu Haopeng</a>
* @date 2022/2/11 15:55
* @since JDK 8
*/
public class DateTimeValidator implements ConstraintValidator<DateTimeStr, String> {
// 日期校验对象
private DateTimeStr dateTimeStr;
/**
* 方法描述: 初始化方法
*
* @param dateTimeStr 日期注释对象
* @author 鲁浩鹏 Lu Haopeng
* @date 2022/2/12 12:29
*/
@Override
public void initialize(DateTimeStr dateTimeStr) {
this.dateTimeStr = dateTimeStr;
}
/**
* 方法描述: 校验器是否有效
*
* @param value 值
* @param context 校验器上下文
* @return {@link boolean}
* @author 鲁浩鹏 Lu Haopeng
* @date 2022/2/12 12:22
*/
@Override
public boolean isValid(String value, ConstraintValidatorContext context) {
try {
if (StrUtil.isNotBlank(dateTimeStr.format())) {
// 指定格式
DateUtil.parse(value, dateTimeStr.format());
} else {
// 不指定格式
DateUtil.parse(value);
}
} catch (Exception ex) {
// 返回失败
return false;
}
// 返回成功
return true;
}
}
3、注解的使用,其中一定要使用@Valid注解
@DateTimeStr(message = "结束时间格式不正确")
private String endDate;
@PostMapping("/date")
public String date(@Valid DateVO vo) {
return vo.getEndDate();
}