POI做office2007数据导出报异常AbstractMethodError: org.apache.xerces.dom.DocumentImpl.getXmlStandalone()Z

一.问题说明

   在做poi导出为xlsx文件时,工具类抛出异常。异常如下:

java.lang.AbstractMethodError: org.apache.xerces.dom.DocumentImpl.getXmlStandalone()Z  
    at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.setDocumentInfo(Unknown Source)  
    at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(Unknown Source)  
    at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(Unknown Source)  
    at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transformIdentity(Unknown Source)  
    at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transform(Unknown Source)  
    at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transform(Unknown Source)  

     在搜遍全网进行jar包冲突问题后,问题依然不得解决。尤其是说xercesImpl.jar和xml-apis.jar这两个jar包的版本问题的,我改完了所有版本后问题依然存在,并没有什么卵用(两行老泪)。 因为异常定位到和xml相关上,所以自己的注意点一直在这。

二.问题解决

      然后我开始求助别人,在朋友的提示下开始在poi的版本上研究。然后开始从最新版本实验。最后发现以下版本是可以使用的


			<dependency>
				<groupId>org.apache.poi</groupId>
				<artifactId>poi-scratchpad</artifactId>
				<version>3.9</version>
			</dependency>
			<dependency>
				<groupId>org.apache.poi</groupId>
				<artifactId>poi-ooxml</artifactId>
				<version>3.9</version>
			</dependency>
			<dependency>
				<groupId>org.apache.poi</groupId>
				<artifactId>poi-ooxml-schemas</artifactId>
				<version>3.9</version>
			</dependency>
			<dependency>
				<groupId>org.apache.poi</groupId>
				<artifactId>poi-excelant</artifactId>
				<version>3.9</version>
			</dependency>

 然后系统开始导出的是一个zip文件,虽然还是不行但是总算有了希望。这里我要说的是其实office2007版本的excel其实就是一个zip文件,然后我改了后缀就好了。出现这种问题多半是文件名和后缀设置的问题,自己注意改代码就好。

      还有一个坑的地方想说下,就是3.9版本在网上的maven仓库上搜索的时候居然是没有的,还是我试出来的(吐血)。写这篇博客是希望遇到类似问题的同行们能够快速解决问题。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
引用\[1\]:NoClassDefFoundError问题和ClassNotFoundException问题不一样,前者一般发生在编译时能找到对应的类,但运行时找不到,后者发生在编译时就找不到对应的类。引用\[2\]:在项目打包部署完成后,使用jar包在部署环境运行时,出现了java.lang.NoClassDefFoundError: org.apache.poi.POIXMLDocument的错误。根据我的了解,这个错误通常是由于缺少依赖包或者依赖冲突导致的。解决这个问题的方法有几种:使用XSSWorkbook替代POIXMLDocument,确保pom文件中引入了正确的依赖包,检查是否有依赖冲突,以及检查是否在使用模块中声明了所需的依赖。另外,还有一种解决办法是修改POIXMLDocumentPart文件中的代码。\[2\]引用\[3\]:为了解决这个问题,你可以在pom文件中添加以下maven依赖: <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>4.1.0</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>4.1.0</version> </dependency> 这样应该能解决Caused by: java.lang.ClassNotFoundException: org.apache.poi.POIXMLTypeLoader的问题。\[3\] #### 引用[.reference_title] - *1* *2* *3* [java.lang.NoClassDefFoundError: org.apache.poi.POIXMLDocument问题排查解决](https://blog.csdn.net/weixin_45937536/article/details/128904930)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值