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

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

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

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

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

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

第二种:

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

第三种:

InputStream inputStream = this.getClass().getResourceAsStream("/excleTemplate/test.xlsx");

 第四种:

File file = ResourceUtils.getFile("classpath:excleTemplate/test.xlsx");
InputStream inputStream = new FileInputStream(file);

经测试:
前三种方法在开发环境(IDE中)和生产环境(linux部署成jar包)都可以读取到,第四种只有开发环境 时可以读取到,生产环境读取失败。
推测主要原因是springboot内置tomcat,打包后是一个jar包,无法直接读取jar包中的文件,读取只能通过类加载器读取。
前三种都可以读取到其实殊途同归,直接查看底层代码都是通过类加载器读取文件流,类加载器可以读取jar包中的编译后的class文件,当然也是可以读取jar包中的excle模板了。

用解压软件打开jar包查看结果如下:


所以总结一下:假如文件是在jar包中,读取方式应当使用基于类加载器读取文件流的方式,比如前三种方法;使用基于java中File方式的读取,在jar包情况下是读取不到的,比方说第四种。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值