动态修改注解

动态修改注解


最近在项目里做数据导出,用到了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就行

拦截器无法直接修改注解中的值,因为注解是在编译期生成的静态元数据,只能通过反射来修改注解中的属性值。但是,拦截器可以在运行时获取注解信息,并根据注解信息动态修改程序的行为。 下面是一个示例,演示了如何使用拦截器获取注解信息,并根据注解信息动态修改程序的行为。 假设我们有一个自定义注解 MyAnnotation,其中有一个属性 value,表示要拦截的方法的名称。我们还有一个拦截器 MyInterceptor,它会在拦截到注解 MyAnnotation 的方法时,根据注解中的 value 属性来动态修改方法中的某个字段的值。 ```java @Target(ElementType.METHOD) @Retention(RetentionPolicy.RUNTIME) public @interface MyAnnotation { String value(); } public class MyInterceptor implements MethodInterceptor { @Override public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable { MyAnnotation annotation = method.getAnnotation(MyAnnotation.class); if (annotation != null && "myMethod".equals(annotation.value())) { // 根据注解中的 value 属性来动态修改方法中的某个字段的值 Field field = obj.getClass().getDeclaredField("myField"); field.setAccessible(true); field.set(obj, "new value"); } // 调用原始方法 return proxy.invokeSuper(obj, args); } } public class MyClass { private String myField = "initial value"; @MyAnnotation("myMethod") public void myMethod() { System.out.println("myMethod is called"); System.out.println("myField = " + myField); } public static void main(String[] args) { Enhancer enhancer = new Enhancer(); enhancer.setSuperclass(MyClass.class); enhancer.setCallback(new MyInterceptor()); MyClass myObj = (MyClass) enhancer.create(); myObj.myMethod(); } } ``` 在上面的示例中,我们使用了 CGLIB 动态代理库来创建 MyClass 对象的代理对象。当调用代理对象的 myMethod 方法时,拦截器 MyInterceptor 会获取方法上的 MyAnnotation 注解,并根据注解中的 value 属性来动态修改 MyClass 对象中的 myField 字段的值。最后,拦截器会调用原始方法 myMethod。运行上面的代码,输出结果如下: ``` myMethod is called myField = new value ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值