使用反射动态校验后台配置某字段是否允许为空

背景:

使用easyExcel读取数据,title不固定,后台可以配置title必填项,title顺序可改变,用户可以自定义title,不存储自定义信息即可,不报错

思路:

不能使用easyExcel使用index的方式读取数据,改成value的方式读取数据;

从数据库读取出配置的title, 先校验上传的excel title 是否包含所有的配置title,不包含则抛异常;

然后通过反射,校验配置的title下的值是否为null, 为空则抛异常:

// 后台配置的title
List<String> fields = new ArrayList<>;
        for (String field : fields) {
// 配置的title是带下划线的,需要转换成对应DTO类的属性,不带下划线
            String fieldName = com.baomidou.mybatisplus.core.toolkit.StringUtils.underlineToCamel(field);
            // 有些title 和 字段名称不一致,需特殊处理
            if(field.equals("asset_price")){
                fieldName = "assetCostAmount";
            }
            if (Objects.isNull(ReflectionUtils.getField(ReflectionUtils.findField(校验的类.class, fieldName), 传进来的行数据))) {
// 抛异常,我这里是存在了一个list里面
                this.exceptionList.add(field + " is null");
            }
        }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值