使用POI导出文件报错:No valid entries or contents found

问题描述

使用POI导出文件报错:No valid entries or contents found

问题原因

maven编译资源文件的时候,对资源文件做了手脚,导致编译出来的target/classes下面的模板文件被破坏!!!
在这里插入图片描述

解决问题

直接奉上完整的配置,自己对照需要排除的文件后缀,添加就行了。两个地方,一上一下加上,maven clean一下项目,重新编译解决。

<build>
		<plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                    <encoding>UTF-8</encoding>
					<compilerArgument>-parameters</compilerArgument>
                </configuration>
            </plugin>
	         <!-- 避免font文件的二进制文件格式压缩破坏 -->
	         <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-resources-plugin</artifactId>
                <configuration>
                    <nonFilteredFileExtensions>
                        <nonFilteredFileExtension>woff</nonFilteredFileExtension>
                        <nonFilteredFileExtension>woff2</nonFilteredFileExtension>
                        <nonFilteredFileExtension>eot</nonFilteredFileExtension>
                        <nonFilteredFileExtension>ttf</nonFilteredFileExtension>
                        <nonFilteredFileExtension>svg</nonFilteredFileExtension>
						<nonFilteredFileExtension>docx</nonFilteredFileExtension>
                    </nonFilteredFileExtensions>
                </configuration>
            </plugin>
		</plugins>
		<resources>
			<resource>
                <directory>src/main/resources</directory>
                <filtering>true</filtering>
            </resource>
			<resource>
				<directory>src/main/java</directory>
				<includes>
					<include>**/*.xml</include>
					<include>**/*.json</include>
					<include>**/*.ftl</include>
					<include>**/*.docx</include>
					<include>static/**</include>
					<include>static/data/ip2region.xdb</include>
				</includes>
			</resource>
		</resources>
	</build>

	<!-- 环境 -->
	<profiles>
		<!-- 开发 -->
		<profile>
			<id>dev</id>
			<properties>
				<profiles.active>dev</profiles.active>
			</properties>
			<activation>
				<!--默认激活配置-->
				<activeByDefault>true</activeByDefault>
			</activation>
		</profile>
		<!-- 测试 -->
		<profile>
			<id>test</id>
			<properties>
				<profiles.active>test</profiles.active>
			</properties>
		</profile>
		<!-- 生产 -->
		<profile>
			<id>prod</id>
			<properties>
				<profiles.active>prod</profiles.active>
			</properties>
		</profile>
	</profiles>
根据参考引用的信息,可从文件加密、POI版本与文件格式匹配、打包资源过滤等方面考虑解决方案。 - **检查文件是否加密**:若公司默认对所有文件加密,被加密的 Excel 文件在导入时会报格式不对的错误,进而出现 `No valid entries or contents found, this is not a valid OOXML (Office Open XML) file` 错误。需确保部署到服务器上的 Excel 文件未被加密,可联系相关人员对文件取消加密处理 [^2]。 - **确认 POI 版本与文件格式匹配**:HSSFWorkbook 用于操作 Excel2003 以前(包括 2003)的版本,扩展名是 `.xls`;XSSFWorkbook 用于操作 Excel2007 后的版本,扩展名是 `.xlsx`。要保证代码中使用POI 处理类与 Excel 文件版本相匹配。若模板是 `.xlsx` 文件,应使用 XSSFWorkbook 解析;若使用错误,可按提示使用正确的类进行解析 [^3]。 - **配置打包资源不过滤**:若把 Excel 文件放到 resources 目录下,打包时可能会把 Excel 配置的 `${变量名}` 进行转义,导致文件格式错误。需在 `pom.xml` 中配置打包资源时不过滤 Excel 文件,具体配置如下: ```xml <build> <resources> <resource> <directory>src/main/resources</directory> <filtering>false</filtering> <includes> <include>**/*.xlsx</include> </includes> </resource> <resource> <directory>src/main/resources</directory> <filtering>false</filtering> <excludes> <exclude>**/*.xlsx</exclude> </excludes> </resource> </resources> </build> ``` 这样可避免打包时对 Excel 文件的配置信息进行错误转义 [^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值