SpringBoot 读取文件代码模版

栏目: Java · 发布时间: 6年前

内容简介:未打包是没问题的,打完包后就发生了错误。开始逐步定位问题。

引言

Alice 上线后,学生导入模版文件下载失败。

SpringBoot 读取文件代码模版

未打包是没问题的,打完包后就发生了错误。开始逐步定位问题。

原方法

File file = ResourceUtils.getFile(ResourceUtils.CLASSPATH_URL_PREFIX + "static/导入学生模板.xlsx");
InputStream inputStream = new FileInputStream(file);
Workbook workbook = new XSSFWorkbook(inputStream);

经测试,问题出在 ResourceUtils.getFile 这个方法上。

ResourceUtils.CLASSPATH_URL_PREFIX + "static/导入学生模板.xlsx"

字符串拼接后就是 classpath:static/导入学生模板.xlsx ,没打包时,该方法能正常获取到该 Excel 文件。

ResourceUtils.getFile 是获取磁盘上的文件,而打完包之后, resources 目录了下的所有资源都被打进了 jar 包,所以不存在相应的 Excel 文件,获取的时候就报错了。找不到文件。

测试

将打好的 jar 包解压,主要的东西都在 BOOT-INF 里。 META-INF 里面有 pom.xml ,应该是存储项目信息的。 org 目录内是 springframework 的一些 class 字节码。

SpringBoot 读取文件代码模版

BOOT-INF 内就是本项目的核心代码与第三方库。

SpringBoot 读取文件代码模版

classes 目录下就是本项目的核心代码,我们的 Excel 就在这里面。

SpringBoot 读取文件代码模版

lib 目录下是项目中引用的第三方 jar 包,里面有我们常用的 slf4jspring-bootjar 包。

SpringBoot 读取文件代码模版

所以, Spring Boot 的项目一般都较大,有一部分原因是把许多第三方包都打包进去了。

SpringBoot 读取文件代码模版

解决方案

@Autowired 一个 ResourceLoader ,然后调用 getResource 方法,加载资源。

想想也不难理解, SpringBoot 启动时读取 application.yml 配置, Spring 的源码中就是使用 ResourceLoader 实现的。

只不过源码中直接用的上下文对象,一个上下文对象不只是一个 IOC 容器,还是一个资源加载器。(上下文其实有很多的功能,可以点开 Spring 源码看一看,很有意思。)

ResourcePatternResolver 派生自 ResourceLoader 接口。

SpringBoot 读取文件代码模版

SpringBoot 读取文件代码模版

代码模版,以后读取文件就这样写,啥毛病没有:

Resource resource = this.resourceLoader.getResource(ResourceUtils.CLASSPATH_URL_PREFIX + "static/导入学生模板.xlsx");

总结

千淘万漉虽辛苦,吹尽狂沙始到金。

一路走来,一路总结。最后留下的,是小本本中记录的代码模版与最佳实践。

SpringBoot 读取文件代码模版


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

思想的未来

思想的未来

(美)劳伦斯﹒莱斯格 / 李旭 / 中信出版社 / 2004-10 / 29.00元

因特网革命已到来,一些人说它已经过去,革命缘何而来?又缘何而去呢? 劳伦斯·莱斯格对因特网革命中为何会出现一种反革命的破坏性力量及后果做出了解释。创作之所以繁荣,是因为因特网保护了创新的公共资源。是因为因特网保护了创新的公共资源。因特网的独特设计营造出一个中立的平台。最广大范围的作者们可在此平台上进行试验。围绕此平台的法律架构对这一自由空间给予了保护,以使文化和信息——我们这个时代的......一起来看看 《思想的未来》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具