SpringBoot 读取文件代码模版

引言

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

clipboard.png

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

原方法

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

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

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

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

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

测试

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

clipboard.png

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

clipboard.png

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

clipboard.png

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

clipboard.png

因此,Spring Boot的项目通常都较大,有一部分缘由是把许多第三方包都打包进去了。对象

clipboard.png

解决方案

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

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

只不过源码中直接用的上下文对象,一个上下文对象不仅是一个IOC容器,仍是一个资源加载器。(上下文其实有不少的功能,能够点开Spring源码看一看,颇有意思。)

ResourcePatternResolver派生自ResourceLoader接口。

clipboard.png

clipboard.png

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

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

总结

千淘万漉虽辛苦,吹尽狂沙始到金。
——刘禹锡《浪淘沙词九首·其九》

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

clipboard.png

相关文章
相关标签/搜索