springboot打jar包启动后,读取jar包中文件采坑

问题记录:
做excel文件导出时,逻辑如下:
1、读取模板配置文件
2、根据模板文件生成新的excel
在做第一步时,本地和服务器上的读取是不一样的,服务器上是jar包启动,本地是开发工具IDEA的main启动,代码如下:
具体可参考【com.xxx.CiticStatisticBiz#exportStatisticBorrowResult】

1、非jar包启动读取模板文件(从绝对路径读取Excel模板)

File path = new File(ResourceUtils.getURL("classpath:").getPath());
logger.info("classpath绝对路径:{}", path.getAbsolutePath());
String excelTemPath = path.getAbsolutePath() + File.separator + "excel" + File.separator;
logger.info("excel模板绝对路径:{}", excelTemPath + excelTemplate);

File file = new File(excelTemPath + excelTemplate);
File newFileDir = new File(exportFilePath);
FileUtils.copyFileToDirectory(file, newFileDir);

2、jar包启动读取模板文件(从相对路径读取Excel模板)

//方法一
InputStream in1 = getClass().getClassLoader().getResourceAsStream(sourcePath);
logger.info("文件流是否为null:{}", null == in1);

//方法二(最终使用)
ClassPathResource resource = new ClassPathResource(sourcePath);
InputStream in = resource.getInputStream();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值