java动态修改注解属性值
但最近在开发过程中遇到了需要根据运行环境来设置 Retention 为 RUNTIME (运行期保留) 的注解属性值的需求。对于上述类 Test,其上有一个注解 @ExcelProperty,需求是这样的: 在月度计划明细前加上时间,车间。InvocationHandler 调用处理器,每一个被代理的实例都有一个调用处理器。可通过其 getInvocationHandler 方法获取注解的代理实例
·
前言
以往来看,注解的属性值一般都是“硬编码”。但最近在开发过程中遇到了需要根据运行环境来设置 Retention 为 RUNTIME (运行期保留) 的注解属性值的需求。举个例子:
@ColumnWidth(value = 20)
@ExcelProperty(value = {"月度计划明细","任务编号"}, index = 0)
@ApiModelProperty(value = "任务号")
private String taskNo;
对于上述类 Test,其上有一个注解 @ExcelProperty,需求是这样的: 在月度计划明细前加上时间,车间。
实现方法
知识点:
保留策略为 RUNTIME 的注解在运行期是保留的。
出于某些技术原因,Java 虚拟机使用的“真实”注释类的实例是动态代理的实例。
Java 注解有一个名为 memberValues 的私有Map,其中存储了属性名称和属性值的k-v对。
基于上述知识点,可以通过反射来访问实例,然后用给定的新值替换现有值。
相关的类:
可通过其 getInvocationHandler 方法获取注解的代理实例
InvocationHandler 调用处理器,每一个被代理的实例都有一个调用处理器
通过反射获取被代理类的实例的属性值
示例代码:
if (clazz != null){
Field[] declaredFields = clazz.getDeclaredFields();
for (int i = 0; i < declaredFields.length; i++) {
Field declaredField = declaredFields[i];
ExcelProperty fieldAnnotation = declaredField.getAnnotation(ExcelProperty.class);
InvocationHandler invocationHandler = Proxy.getInvocationHandler(fieldAnnotation);
Field memberValues = invocationHandler.getClass().getDeclaredField("memberValues");
memberValues.setAccessible(true);
String[] value = fieldAnnotation.value();
String a = headName+value[0];
String[] arr = {a,value[1]};
Map o = (Map)memberValues.get(invocationHandler);
o.put("value",arr);
}
}
更多推荐
已为社区贡献1条内容
所有评论(0)