Apache POI 依赖版本冲突导致 NoSuchFieldError: Factory 报错

bash 复制代码
> mvn dependency:tree   -Dincludes=org.apache.poi
.....
[INFO]       +- org.apache.poi:poi:jar:4.1.2:compile
[INFO]       +- org.apache.poi:poi-ooxml:jar:4.1.2:compile
[INFO]       +- org.apache.poi:poi-scratchpad:jar:4.1.2:compile
[INFO]       +- org.apache.poi:poi-ooxml-schemas:jar:4.1.2:compile
[INFO]       \- org.apache.poi:ooxml-schemas:jar:1.4:compile
[INFO] 

当前项目的问题已经完全清晰了:Apache POI 依赖版本严重冲突,直接导致了 NoSuchFieldError: Factory 报错。


问题分析:同时引入了 4.1.25.3.0 的 POI 版本

你打印的依赖树显示:

来自手动添加的依赖(或较新服务模块):

text 复制代码
org.apache.poi:poi-excelant:jar:5.3.0

来自 microservice-api 的传递依赖:

text 复制代码
org.apache.poi:poi:jar:4.1.2
org.apache.poi:poi-ooxml:jar:4.1.2
org.apache.poi:poi-scratchpad:jar:4.1.2
org.apache.poi:poi-ooxml-schemas:jar:4.1.2
org.apache.poi:ooxml-schemas:jar:1.4

这会导致最终运行时 不同版本的类混用 ,例如你代码是基于 5.3.0 写的,但运行时加载的是 4.1.2XSSFWorkbook.class,因此报如下错:

text 复制代码
Exception in thread "main" java.lang.NoSuchFieldError: Factory
	at org.apache.poi.xssf.usermodel.XSSFWorkbook.onWorkbookCreate(XSSFWorkbook.java:508)

正确解决方案:排除旧版本,统一使用 POI 5.3.0

你应该在主项目的 pom.xml 中添加 <dependencyManagement><exclusions>,强制统一为 5.3.0


方法一:在 pom.xml 中显式排除旧版本 poi 依赖

xml 复制代码
<dependency>
    <groupId>com.example.microservice.service</groupId>
    <artifactId>microservice-api</artifactId>
    <version>1.0-SNAPSHOT</version>
    <exclusions>
        <exclusion>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
        </exclusion>
        <exclusion>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
        </exclusion>
        <exclusion>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml-schemas</artifactId>
        </exclusion>
        <exclusion>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-scratchpad</artifactId>
        </exclusion>
        <exclusion>
            <groupId>org.apache.poi</groupId>
            <artifactId>ooxml-schemas</artifactId>
        </exclusion>
    </exclusions>
</dependency>

方法二:用 dependencyManagement 统一版本(推荐)

xml 复制代码
<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>5.3.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>5.3.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-excelant</artifactId>
            <version>5.3.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-scratchpad</artifactId>
            <version>5.3.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml-schemas</artifactId>
            <version>5.3.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.xmlbeans</groupId>
            <artifactId>xmlbeans</artifactId>
            <version>5.2.1</version>
        </dependency>
    </dependencies>
</dependencyManagement>

然后只在你项目中声明依赖即可,不必重复指定版本。


最后一步:执行清理与重编译

bash 复制代码
# 清除旧缓存
rm -rf ~/.m2/repository/org/apache/poi

# 然后重新构建
mvn clean install

总结

结论
错误原因 poi:5.3.0poi:4.1.2 冲突,导致 XSSFWorkbook 类结构不一致
根源 microservice-api 引入了旧版本 POI
解决方案 <dependency> 中排除旧版本,或通过 <dependencyManagement> 强制版本统一
必须操作 mvn clean install 清理旧缓存,确保生效
相关推荐
用户83071968408215 分钟前
Java IO三大模型(BIO/NIO/AIO)超详细总结
java
sheji341615 分钟前
【开题答辩全过程】以 基于SSM的花店销售管理系统为例,包含答辩的问题和答案
java
Mr_sun.26 分钟前
Day09——入退管理-入住-2
android·java·开发语言
MAGICIAN...37 分钟前
【java-软件设计原则】
java·开发语言
JH307343 分钟前
为什么switch不支持long
java
盐真卿1 小时前
python第八部分:高级特性(二)
java·开发语言
上海合宙LuatOS1 小时前
LuatOS核心库API——【audio 】
java·网络·单片机·嵌入式硬件·物联网·音视频·硬件工程
汤姆yu1 小时前
基于springboot的尿毒症健康管理系统
java·spring boot·后端
TT哇1 小时前
【实习】银行经理端线下领取扫码功能实现方案
java
野犬寒鸦1 小时前
从零起步学习JVM || 第一章:类加载器与双亲委派机制模型详解
java·jvm·数据库·后端·学习