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
注解,加上注解未导出内容,导致报空指针,框架中并未校验当没有数据赋值为空,而是直接抛出空指针
解决办法就是,将注解与要导出的内容一一对应,不能多也不能少