jeecgBoot导出功能错误

jeecgBoot导出功能错误


问题描述

例如:jeecgBoot导出功能错误提示空指针,导出错误
APP 中接收数据代码:

java.lang.NullPointerException: null
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at org.jeecgframework.poi.excel.export.base.ExportBase.getCellValue(ExportBase.java:208)
	at org.jeecgframework.poi.excel.export.base.ExcelExportBase.createListCells(ExcelExportBase.java:341)
2023-05-31 14:01:15.745 [http-nio-8080-exec-6] ERROR o.a.c.c.C.[.[.[/jeecg-boot].[dispatcherServlet]:175 - Servlet.service() for servlet [dispatcherServlet] in context with path [/jeecg-boot] threw exception [Request processing failed; nested exception is org.jeecgframework.poi.exception.excel.ExcelExportException: Excel导出错误] with root cause
org.jeecgframework.poi.exception.excel.ExcelExportException: Excel导出错误
	at org.jeecgframework.poi.excel.export.ExcelExportServer.createSheet(ExcelExportServer.java:208)
	at org.jeecgframework.poi.excel.ExcelExportUtil.exportExcel(ExcelExportUtil.java:73)
	at org.jeecgframework.poi.excel.view.JeecgEntityExcelView.renderMergedOutputModel(JeecgEntityExcelView.java:69)
	at org.springframework.web.servlet.view.AbstractView.render(AbstractView.java:316)
	at org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1401)
	at org.springframework.web.servlet.DispatcherServlet.processDispatchResult(DispatcherServlet.java:1145)
	at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1084)

原因分析:

空指针一定是有数据为空:首先想到字典未获取到,然后判断为表格内容为空

当传入数据时有多个字段以及子表字段,其注解均有@Dict以及@Excel,然后数据从这两方面入手查看,字典值都配对成功,不是字典的原因,参数也都已经完善暂未发现空数据。


解决方案:

debug查看具体哪里为空,查看传入内容

debug发现了一个未导出字段,但是其也加了@Excel注解,加上注解未导出内容,导致报空指针,框架中并未校验当没有数据赋值为空,而是直接抛出空指针
解决办法就是,将注解与要导出的内容一一对应,不能多也不能少

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值