springboot导包显示不存在_SpringBoot打成jar包部署,Excel模板下载文件遇到的问题...

本文介绍了SpringBoot项目在打包成jar后,读取resource目录下文件及Excel模板下载时遇到的两个问题。问题一是通过路径无法找到文件,原因是文件被打包,需通过流读取;问题二是Excel模板下载文件损坏,可能是过滤器对二进制文件处理不当。文中提供了三种解决方案:使用Spring Boot静态资源下载、通过流读取资源并文件输出流下载以及利用POI的Workbook直接输出流下载。
摘要由CSDN通过智能技术生成

问题一. 读取resource 目录下文件时出现路径找不到

在本机测试都很顺利,当打包jar文件放到服务器上测试的时候发现了类似下面的异常信息:

java.nio.file.NoSuchFileException: file:/app.jar!/BOOT-INF/classes!/xxx.xlsx

原因:spring boot 将项目打包为jar,使用 java - jar 包名 在服务器上运行。此时文件为打包文件,所以不能通过路径获取到文件。类似不能读取压缩包中的文件,必须先解压缩。结论:spring boot 中的文件只能通过流来进行读取。

可以通过以下方法进行流的读取。

InputStream in = this.getClass().getClassLoader().getResourceAsStream("xxx.xlsx");

问题二. Excel模板下载文件损坏

在本机测试都很顺利,当打包jar文件放到服务器上时下载完文件提示文件损坏

问题原因分析:

一开始度娘查到各种各样的说法,比如修改response请求回应头,比如使用ByteArrayHttpMessageConverter,比如修改文件读取方式,没点屁用!!

后面看到另外一篇文章,maven 打包的时候,使用了filter,其原理是处理文本文件,并将其替换变量,对于二进制文件有问题,参考https://www.jianshu.com/p/9d39745f6ce6;

对于这种说法,我实际的操作过程中,jar包里面的Excel文件是正常的,所以理论上不是这个问题&#x

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值