【辰兮要努力】:hello你好我是辰兮,很高兴你能来阅读,昵称是希望自己能不断精进,向着优秀程序员前行!
博客来源于项目以及编程中遇到的问题总结,偶尔会有读书分享,我会陆续更新Java前端、后台、数据库、项目案例等相关知识点总结,感谢你的阅读和关注,希望我的博客能帮助到更多的人,分享获取新知,大家一起进步!
吾等采石之人,应怀大教堂之心,愿大家奔赴在各自的热爱里…
一、业务场景
最近在做一个下载Excel模块和导入模板的业务,原来模板是静态的,前端直接下载即可,即不需要后端代码,现在根据业务需要将此修改为动态下载
//直接访问文件的路径即可实现下载
window.location.href = url
业务描述:现在是想要先读取一个Java程序resource下的Excel文件,然后往此Excel里面插入部分数据,然后再下载
问题:如何用Java程序读取到自己的resource目录下的Excel文件呢 ?
Java读取文件要么获取此文件的路径,要么将此文件读取为文件流,放入某一个封装对象中
我的业务场景就是要将文件流放到某一个Excel的封装对象中
本地的话直接丢一个绝对路径给file类可以创建一个文件对象,但是线上不行Linux中对应的路径是随着IP动态改变的,所以不能使用绝对路径
我们需要找一个方法在window和linux都可以获取resource路径的方法
二、代码案例
使用如下的代码即可获取此文件的文件流
案例一
InputStream inputstream = this.getClass().getClassLoader().getResourceAsStream("helloWorld/Test.xlsx");
使用如下的方法,我们可以看到可以输出对应的文件流
如果我们修改成一个不存在的路径,即文件不存在,此时读取为空,即可同步验证上述代码可以获取对应的文件流
案例二
使用如下的方式也可以获取到文件流
ClassPathResource classPathResource = new ClassPathResource("hello/Test.xlsx");
//获取文件流
try (InputStream fileStream = classPathResource.getInputStream()) {
System.out.println(fileStream);
}catch (Exception e){
//处理异常
}
代码实践如下
补充案例:这里和第一个代码类似,主要是多了如何在获取这个文件的路径,并将此文件放入新的file类找那个
ClassLoader loader = TestPath.class.getClassLoader();
URL url = loader.getResource("hello/Test.xlsx");
System.out.println(url);
File file = new File(url.getFile());
System.out.println(file);
InputStream input = loader.getResourceAsStream("hello/Test.xlsx");
System.out.println(input);
实践代码如下:可以获取文件的绝对路径,也可以获取文件流
补充案例:如下的方法我测试可以在本地获取自己想要的resource文件,也在本地打印出了自己文件的文件路径,代码如下可自行测试
public static void main(String[] args) {
//获取根目录
String path = null;
try {
path = ResourceUtils.getURL("classpath:").getPath();
} catch (FileNotFoundException e) {
e.printStackTrace();
}
System.out.println("path:" + path);
File file = null;
try {
file = new File(ResourceUtils.getURL("classpath:").getPath());
} catch (FileNotFoundException e) {
e.printStackTrace();
}
System.out.println("file:"+file.getAbsolutePath());
//相对路径-封装文件
File upload = new File(file.getAbsolutePath(),"/hello/Test.xlsx");
System.out.println("upload url:"+upload.getAbsolutePath());
try {
//如果出现中文的问题可以进行如下的转码操作
System.out.println(URLDecoder.decode(upload.getAbsolutePath(),"UTF-8"));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}
输出结果如下
path:/D:/workSpace/cwgl/target/classes/
file:D:\workSpace\cwgl\target\classes
upload url:D:\workSpace\cwgl\target\classes\hello\Test.xlsx
D:\workSpace\cwgl\target\classes\hello\Test.xlsx
线上的话大家自行尝试,建议使用前面两种方式获取对应文件
三、拓展补充
Java中读取文件:
1、通过使用java.io方法读取,相对于当前用户目录的相对路径读取;
2、通过使用java.lang.ClassLoader方法读取,相对于classpath的相对路径读取。
开发过程也遇到了很多问题,相关问题总结请参考
缓存问题解决:Java代码读取文件缓存问题解决(案例详解)
File类参考:深入学习Java文件类File类(Demo详解)
上传组件基础学习可参考:Element-UI中el-upload上传组件(demo详解)
MultipartFile类参考:MultipartFile工具类(方法详解)
目前自己对文件上传方面还有很多的不足,我会陆续整理实践,期待更多的沟通交流和进步……
非常感谢你阅读到这里,如果这篇文章对你有帮助,希望能留下你的点赞👍 关注❤️ 分享👥 留言💬thanks!!!
愿你们奔赴在自己的热爱里!