获取项目中已经生成在资源文件路径下的excel的位置

本文讨论了在Java应用中,如何在本地和服务器环境下正确获取资源文件,尤其是Excel的位置。在服务器上运行时,由于路径处理的差异,需要使用绝对路径而非相对路径。文中列举并测试了四种不同的方法,发现前三种方法,通过类加载器读取文件流,无论在开发还是生产环境都能成功,而第四种基于File的方式在生产环境的jar包中失败。总结建议在jar包中读取文件应使用类加载器方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当我在自己本地运行时,代码这样写,是没问题的,但是之后放在服务器上发下一值找不到路径

这是在本地写的方法,两个都好使,一个是返回文件流,一个是返回string类型的文件路径。

在上传到服务器上不好使之后改为用线程获取,成功,之后在本地运行也成功。有一点要注意就是路径前面在服务器上要不能加点,在本地要加点。大概原因是有点是找相对路径,不加点找的是绝对路径,在服务器上打成jar包之后无法找到相对路径,只能找绝对路径。这一点要注意。

之后又了解到还有另外三种方法:

第二种:

ClassPathResource classPathResource = new ClassPathResource("excleTemplate/test.xlsx");
InputStream inputStream =classPathResource.getInputStream();

第三种:

InputStream inputStream = this.getClass().getResourceAsStream("/excleTemplate/test.xlsx"
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值