项目中有需求需要读取resources/tempalte/xx.xlsx文件,并写入数据并导出.最初代码已经本地自测代码如下:
ClassPathResource resource = new ClassPathResource("template/导出表模板.xlsx");
boolean isFile = resource.isFile();
//如果不存在返回
if(!isFile){
log.error("导出文件不存在");
return;
}
InputStream in = new FileInputStream(resource.getFile().getPath());
本地测试没有问题,能够读取到文件并导出,打jar包上linux环境运行,不成功,日志报出"导出文件不存在",检查jar中对应目录下也存在导出表模板.xlsx,打jar后ClassPathResource不到路径.
解决代码为:
InputStream in = Thread.currentThread().getContextClassLoader().getResourceAsStream("template/导出表模板.xlsx");
使用这个完美解决~
百度查询还有以下两种,未测试,仅供参考:
1.
InputStream inputStream = this.getClass().getResourceAsStream("/excleTemplate/test.xlsx");
2.
File file = ResourceUtils.getFile("classpath:excleTemplate/test.xlsx");
InputStream inputStream = new FileInputStream(file);