转载

SpringBoot 读取文件代码模版

引言

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 读取文件代码模版

原文  https://segmentfault.com/a/1190000019285042
正文到此结束
Loading...