一、问题现象

在导出 Excel 过程中,程序报错如下:

Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/io/output/UnsynchronizedByteArrayOutputStream
 at PIOTest.main(PIOTest.java:31)
Caused by: java.lang.ClassNotFoundException: org.apache.commons.io.output.UnsynchronizedByteArrayOutputStream
 at java.net.URLClassLoader.findClass(URLClassLoader.java:382)

二、问题原因

通过报错信息可以看出,这个异常通常出现在你在代码里使用了 org.apache.commons.io.output.UnsynchronizedByteArrayOutputStream 这个类,但是该类所在的依赖包 commons-io 并没有被引入或不存在。


三、解决方案

解决这个问题,需要将 commons-io 的包引入到项目中。

如果使用 Maven 管理依赖,可以在 pom.xml 文件中添加以下依赖:

		<!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.11.0</version>
        </dependency>

注意:此处必须使用 2.11.0 及以上版本,不然还是会报 NoClassDefFoundError

Maven 远程仓库地址:https://mvnrepository.com/artifact/commons-io/commons-io

在这里插入图片描述
在这里插入图片描述


PS

如果没有使用Maven,可以手动下载 commons-io 的 jar 包,并将其添加到项目的 lib 目录或者 classpath 中。

如果已经将 commons-io 的包引入到项目中,仍然出现 ClassNotFoundException 异常,则有可能是因为编译环境和运行环境不一致,需要检查编译和运行的环境是否一致。

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐