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

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

2058

被折叠的 条评论
为什么被折叠?



