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 清理旧缓存,确保生效
相关推荐
我只想困告15 小时前
day02-RabbitMQ 2026-05-14
java·spring·rabbitmq
Nontee15 小时前
Java 后端面试题目全集
java·开发语言·面试
jran-15 小时前
Docker dockerfile镜像制作&compose服务编排&私有仓库
java·docker·容器
Chase_______15 小时前
【Java杂项】0.1 + 0.2 为什么不等于 0.3?IEEE 754 与 BigDecimal 精度避坑
java·开发语言·python
ch.ju15 小时前
Java Programming Chapter 4——Static part
java·开发语言
YDS82915 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— 环境搭建和项目初始化
java·springboot·agent·rag·deepseek
ChoSeitaku15 小时前
04.数组
java·开发语言·数据结构
float_com15 小时前
【java进阶】------ 多线程【实际案例分析】
java
用户2986985301415 小时前
Java 中的 Word 变量管理:添加、统计、获取与删除
java·后端
郭龙_Jack16 小时前
Java 17 到 Java 25:LTS 升级的全面收益与迁移指南
java·开发语言·python