问题一. 读取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