EasyExcel自定义非空注解,类似@NotBlank注解。

写在前面

今天开发excel导入数据的功能,一切都很顺利。但是当看到需求文档,其中有几个列的数据是必输的。于是我想到了,在实体类属性上加@NotBlank注解不就可以了嘛!但是我写接口入参是一个文件,所以解析实体后这个注解根本不起作用。于是想到自己创建自定义注解,校验非空的列。

正题

1.创建注解类

写过注解的同学应该都比较熟悉了,直接上代码。

字符串非空校验

/**
 * Excel导入必填校验注解
 *
 */
@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface ExcelValid {
    String message() default "非空字段必填";
}

字符串长度校验注解

@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface ExcelStrLengthValid {
    int length() default 0;
    String message() default "字段超长";
}

int长度校验

@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface ExcelIntValid {
    int min();
    int max();
    String message() default "整数超过长度范围";
}

还可以写其他类型的校验注解,这里就不展示了。

2.导入字段检验逻辑

public class ExcelInValid {

    /**
     * Excel导入字段校验
     *
     * @param object 校验的JavaBean 其属性须有自定义注解
     * @author linmaosheng
     */
    public static void valid(Object object) {
        Field[] fields = object.getClass().getDeclaredFields();
        for (Field field : fields) {
            field.setAccessible(true);
            //属性的值
            Object fieldValue = null;
            try {
                fieldValue = field.get(object);
            } catch (IllegalAccessException e) {
                //BusinessException是我自定义的异常,这里需要
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值