java通过注解翻译字典
最近在写代码时遇到⼀个需要将entity字段通过字典翻译成真实值的场景,原来的做法是通过主表字段和字典表关联的形式,当⼀个需要⼤量翻译的场景时,⼤量的关联会造成sql阅读的不友好,所以就在想有什么可以偷懒的⽅法。。。
⾸先⼀个想法就是通过注解,实例化entity时就可以同步翻译了。
先⾃定义注解
@Target({ElementType.FIELD,ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface DictCovert {
/**
* 字典key
* @return
*/
String key() default "";
单词忘不了
/**
* 是否使⽤redis
* @return
*/
boolean redis() default fal;
}
然后在需要转换的entity属性上加上注解和该属性的key
嗤之以鼻什么意思
/**
* 性别
*/
@DictCovert(key = "gender",redis = true)
private Integer gender;
有了注解,⾸先想到的就是通过AOP去切该注解@Pointcut("@annotation(*.*.*.DictCovert)"),捕获到切点时同步处理数据就⾏
赶紧写好代码运⾏,发现没有如愿以偿,因为我们⾃定义的注解加在了entity上,但是entity并没有交给spring管理,所以切点根本没有奏效,草(⼀种植物)!!。。。。。
爱你单词
于是⼜想到了通过⾃定义MessageConverter的形式捕获注解处理,然后依旧是草(⼀种植物)
最终最终还是找到通往罗马的路了
通过注解@ControllerAdvice处理全局的数据,然后继承ResponBodyAdvice接⼝重写beforeBodyWrite⽅法,处理数据
直接贴代码(代码有点长,个⼈⽔平有限,轻喷 )
@ControllerAdvice
@Slf4j
ratepublic class DictCovertHandler implements ResponBodyAdvice {
@Autowired
意大利语在线课程
private RedisTemplate redisTemplate;
@Autowired
private ISysDicService sysDicService;
private final String DICTDIR = "DICT:";
@Override
public boolean supports(MethodParameter returnType, Class converterType) {
/
/直接为true,所有返回结果都应该检验
return true;
房租会计分录}
@Override
public Object beforeBodyWrite(Object body, MethodParameter returnType, MediaType lectedContentType, Class lectedConverterType, ServerHttpReque try{
Result result = (Result)body;
//获取返回值列表
List<?> resList =new ArrayList<>();
northwest airlinesObject resValue = Data();
//未分页结果
if(resValue instanceof ArrayList){
resList =(ArrayList) resValue;
}
//分页结果tpp是什么意思
if(resValue instanceof Page){
resList = ((Page<?>) resValue).getRecords();
}
//⾮查询结果
if(CollectionUtil.isEmpty(resList)){
return body;
}
List<Map<String,Object>> resultList = new ArrayList();
for (Object entity : resList) {
//拿到bean将其转换为map输出
Map<String,Object> map = BeanUtil.beanToMap(entity);
//获取字段列表
Field[] fields = Class().getDeclaredFields();
if(fields.length != 0){
for (Field field : fields) {
//存放真实值
String realValue =null;
//获取注解列
DictCovert dictCovert = Annotation(DictCovert.class);
if(!Objects.isNull(dictCovert)){
String dictKey = dictCovert.key();
//是否使⽤redis,default:fal
boolean redis = dis();
String fieldName = Name();
String methodName = "get"+dictKey.substring(0,1).toUpperCa()+dictKey.substring(1,dictKey.length());
Method method = Class().getMethod(methodName,null);
//获取字典原始值
Object value =method.invoke(entity,null);
if(Objects.isNull(value)){
continue;
}gym怎么读
String redisKey= dictKey+"_"+value;
//使⽤redis
if(redis){
//从redis加载字典真实信息
realValue = (String) redisTemplate.opsForValue().get(DICTDIR+redisKey);
}
if(StrUtil.isBlank(realValue)){
SysDic sysDic = ById(Integer.String()));
if(!Objects.isNull(sysDic)){
realValue = DictLabel();
/
/将结果塞⼊redis
redisTemplate.opsForValue().t(DICTDIR+redisKey,realValue);
}
}
map.put(fieldName+"String",realValue);
}
}
}
resultList.add(map);
}
result.tData(resultList);
return result;
}catch (Exception e ){
//翻译失败返回原来的值
<("字典翻译失败",e);
return body;
}
}
}
grand canyon最后在返回值中会有⼀个带有String的属性,那就是翻译后的值
OVER!!