Java代码实现读取resource文件(Springboot项目-案例详解)

举报
辰兮 发表于 2022/03/23 00:54:47 2022/03/23
【摘要】 【辰兮要努力】:hello你好我是辰兮,很高兴你能来阅读,昵称是希望自己能不断精进,向着优秀程序员前行! 博客来源于项目以及编程中遇到的问题总结,偶尔会有读书分享,我会陆续更新Java前端、后台、...

【辰兮要努力】:hello你好我是辰兮,很高兴你能来阅读,昵称是希望自己能不断精进,向着优秀程序员前行!

博客来源于项目以及编程中遇到的问题总结,偶尔会有读书分享,我会陆续更新Java前端、后台、数据库、项目案例等相关知识点总结,感谢你的阅读和关注,希望我的博客能帮助到更多的人,分享获取新知,大家一起进步!

吾等采石之人,应怀大教堂之心,愿大家奔赴在各自的热爱里…


一、业务场景

最近在做一个下载Excel模块和导入模板的业务,原来模板是静态的,前端直接下载即可,即不需要后端代码,现在根据业务需要将此修改为动态下载

//直接访问文件的路径即可实现下载
window.location.href = url 

  
 
  • 1
  • 2

业务描述:现在是想要先读取一个Java程序resource下的Excel文件,然后往此Excel里面插入部分数据,然后再下载

问题:如何用Java程序读取到自己的resource目录下的Excel文件呢 ?

在这里插入图片描述

Java读取文件要么获取此文件的路径,要么将此文件读取为文件流,放入某一个封装对象中

我的业务场景就是要将文件流放到某一个Excel的封装对象中
在这里插入图片描述
本地的话直接丢一个绝对路径给file类可以创建一个文件对象,但是线上不行Linux中对应的路径是随着IP动态改变的,所以不能使用绝对路径

我们需要找一个方法在window和linux都可以获取resource路径的方法


二、代码案例

使用如下的代码即可获取此文件的文件流

案例一

   InputStream inputstream = this.getClass().getClassLoader().getResourceAsStream("helloWorld/Test.xlsx");

  
 
  • 1

使用如下的方法,我们可以看到可以输出对应的文件流

在这里插入图片描述

如果我们修改成一个不存在的路径,即文件不存在,此时读取为空,即可同步验证上述代码可以获取对应的文件流
在这里插入图片描述


案例二

使用如下的方式也可以获取到文件流

       ClassPathResource classPathResource = new ClassPathResource("hello/Test.xlsx");
        //获取文件流
        try (InputStream fileStream = classPathResource.getInputStream()) {
            System.out.println(fileStream);
        }catch (Exception e){
            //处理异常
        }

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

代码实践如下
在这里插入图片描述


补充案例:这里和第一个代码类似,主要是多了如何在获取这个文件的路径,并将此文件放入新的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);

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

实践代码如下:可以获取文件的绝对路径,也可以获取文件流

在这里插入图片描述


补充案例:如下的方法我测试可以在本地获取自己想要的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();
        }
    }

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27

输出结果如下

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

  
 
  • 1
  • 2
  • 3
  • 4

线上的话大家自行尝试,建议使用前面两种方式获取对应文件


三、拓展补充

Java中读取文件:
1、通过使用java.io方法读取,相对于当前用户目录的相对路径读取;
2、通过使用java.lang.ClassLoader方法读取,相对于classpath的相对路径读取。


开发过程也遇到了很多问题,相关问题总结请参考

缓存问题解决:Java代码读取文件缓存问题解决(案例详解)

File类参考:深入学习Java文件类File类(Demo详解)

上传组件基础学习可参考:Element-UI中el-upload上传组件(demo详解)

MultipartFile类参考:MultipartFile工具类(方法详解)
在这里插入图片描述

目前自己对文件上传方面还有很多的不足,我会陆续整理实践,期待更多的沟通交流和进步……
在这里插入图片描述


非常感谢你阅读到这里,如果这篇文章对你有帮助,希望能留下你的点赞👍 关注❤️ 分享👥 留言💬thanks!!!

2021年5月31日20:30:27 愿你们奔赴在自己的热爱里!

文章来源: blessing.blog.csdn.net,作者:辰兮要努力,版权归原作者所有,如需转载,请联系作者。

原文链接:blessing.blog.csdn.net/article/details/117428214

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。