动态修改注解

动态修改注解


最近在项目里做数据导出,用到了EasyEexcel,但是表头字段值是动态变化的,去下图,需要修改@ExcelProperty的value值
就是修改它对应的value值

 public Object changeAnnotation(String className, Map<String,Object> maps){
        try {
			//这里map的key是实体类字段名,value是需要动态修改的注解值
            Class<?> name =  Class.forName(className);
            T instance = (T) name.newInstance();
            if (maps.size()>0){
                for (String key:maps.keySet()){
                    Field value = instance.getClass().getDeclaredField(key);
                    value.setAccessible(true);
                    //ExcelProperty 是一个注解注解
                    ExcelProperty apiParam =  value.getAnnotation(ExcelProperty.class);
                    java.lang.reflect.InvocationHandler invocationHandler = Proxy.getInvocationHandler(apiParam);
                    Field memberValues = invocationHandler.getClass().getDeclaredField("memberValues");
                    memberValues.setAccessible(true);
                    Map<String, Object> values = (Map<String, Object>) memberValues.get(invocationHandler);
                    String[] val = (String[]) values.get("value");
                    System.out.println("------改之前:"+ Arrays.toString(val));
                    values.put("value", new String[]{maps.get(key).toString()});//修改属性
                    System.out.println("-----------------");
                    value.setAccessible(true);
                    ExcelProperty apiParam1 = (ExcelProperty) value.getAnnotation(ExcelProperty.class);

                    System.out.println("------改之后:"+ Arrays.toString(apiParam1.value()));
                }

            }
          return instance;

        } catch (Exception e) {
            e.printStackTrace();
        }
        return new Object.getClass();

    }

调用了上边的方法后直接调用getClass()传给EasyExcel就行

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值