笔记:记一次使用EasyExcel重写convertToExcelData方法无法读取@ExcelDictFormat注解的问题(已解决)

笔记:记一次使用EasyExcel重写convertToExcelData方法无法读取@ExcelDictFormat注解的问题(已解决)

PS:解决方法在最后。

因为帮别人做一个导出,跟我说查询已经做好,正常按着查询写个导出,那不是简简单单的事情,但是,问题出现了,写完导出之后,发现居然报错了!报错如下:

字典键值转换居然报错了!反复看导出类配置,但是完全看不出有什么问题,心态逐渐爆炸,无奈,debug看看源码吧。

java 复制代码
    @ExcelProperty(value = "发货状态", converter = ExcelDictConvert.class)
    @ExcelDictFormat(dictType = "send_status")
    private String orderSendStatus;

首先从doWrite开始:

点开excelWriter->excelBuilder->context->clazz->reflectionData->referent->declaredFields,可以看到此时的class还是正常的。

一直往下:




到这时都是正常的,直到addJavaObjectToExcel方法,问题出现了:

打开excelContentProperty这个对象的属性,可以看到注解属性不见了!见鬼了!

如果眼神好的话,想必已经发现问题了,可惜我眼神不好, 来来回回看了几遍才发现问题,两次clazz类的id不一样了,前面是9136,后面是9135,但是正常不会这样,因为同一个java对象传参是不会变的。再仔细看看,发现这里面的对象是实体类,而不是导出类!

但是我记得明明查询用的是导出类,怎么会变成实体类。

但是再次debug看数据实际上确实是实体类:

再往下找,发现问题所在:

原来是查询的时候使用的映射是实体类,所以导致读取不到@ExcelDictFormat,因为压根就不是导出类,怎么能读取到注解。。。

解决方法也很简单:
1、把xml映射map路径从实体类改为导出类
2、或者把resultMap直接改成resultType,值为导出类路径
1和2选一个改,只要正常返回导出类对象,问题就解决了

相关推荐
CV搬运专家几秒前
Rust 控制流深度解析:安全保证与迭代器哲学
java·开发语言
寒月霜华2 分钟前
JavaWeb后端-JDBC、MyBatis
spring boot·junit·mybatis
WaibiJiangzhi4 分钟前
《动手学深度学习》学习笔记——02深度学习介绍
笔记·学习
lkx097885 分钟前
笔记C++语言,太焦虑了
前端·c++·笔记
无敌少年小旋风5 分钟前
05-面试解析 Agent 理论 + 实践(Spring AI Alibaba)
人工智能·spring·面试
张泽腾669 分钟前
<FreeRTOS>
java·开发语言
低音钢琴12 分钟前
【SpringBoot从初学者到专家的成长25】认识SpringBoot中的Spring Expression Language (SpEL)
spring boot·后端·spring·spel
BeingACoder25 分钟前
【项目实践】公寓租赁项目(九):SpringBoot与Redis整合的快速入门使用
java·spring boot·redis
岑梓铭26 分钟前
《考研408数据结构》第六章(5.4树和森林)复习笔记
数据结构·笔记·考研·算法·408·ds
Javatutouhouduan1 小时前
我用ChatGPT,给RabbitMQ加了个连接池
java·spring·rabbitmq·消息中间件·后端开发·java程序员·java八股文