java学习

@Autowired 注入为空怎么办

通过反射获取注解的值和名字

public class ExcelImportValid {
    /**
     * Excel导入字段校验
     * @param object 校验的JavaBean 其属性须有自定义注解
     */
    public static String valid(Object object) throws Exception {
        Field[] fields = object.getClass().getDeclaredFields();
        String err="";
        for (Field field : fields) {
            //设置可访问
            field.setAccessible(true);
            //属性的值
            Object fieldValue = null;
            String[] fieldName=null;
            try {
//                注解数值
                fieldValue = field.get(object);
//                注解名字
                if(field.isAnnotationPresent(ExcelProperty.class)){
                    fieldName= field.getDeclaredAnnotation(ExcelProperty.class).value();
                }

            } catch (IllegalAccessException e) {
                throw new Exception(
                        field.getAnnotation(ExcelValid.class).message());
            }

            //是否包含必填校验注解

//            先判断必填是否为空,再判断类型
            boolean isExcelValid = field.isAnnotationPresent(ExcelValid.class);
            if (isExcelValid && Objects.isNull(fieldValue)) {
                err=err.concat(field.getAnnotation(ExcelValid.class).message());
            }
//            判断日期类型
            if(field.isAnnotationPresent(DateTimeFormat.class)){
                DateFormat formatter = new SimpleDateFormat("yyyy-MM-dd");
                try{
                    Date date = formatter.parse((String) fieldValue);
                }catch(Exception e){
                    err=err.concat(fieldName[0]+"日期格式错误");
                }
            }

        }
        if(err.length()>0){
            return err;
        }else{
            return "true";
        }

    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值