我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Springboot如何导出文件

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Springboot如何导出文件

这篇文章主要介绍Springboot如何导出文件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

后端代码

可以把请求设置为post,我这里是Get

 @RequestMapping(value = "/download", method = RequestMethod.POST)    public void download(HttpServletRequest request, HttpServletResponse res) throws Exception {        File excelFile = new File("/Users/i501695/GitHUbProject/EN_ProductIntergration/databaseclient/class="lazy" data-src/main/resources/Files/ProductTemplateCopy.xlsx");        res.setCharacterEncoding("UTF-8");        String realFileName = excelFile.getName();        res.setHeader("content-type", "application/octet-stream;charset=UTF-8");        res.setContentType("application/octet-stream;charset=UTF-8");        //加上设置大小下载下来的.xlsx文件打开时才不会报“Excel 已完成文件级验证和修复。此工作簿的某些部分可能已被修复或丢弃”        res.addHeader("Content-Length", String.valueOf(excelFile.length()));        try {            res.setHeader("Content-Disposition", "attachment;filename=" + java.net.URLEncoder.encode(realFileName.trim(), "UTF-8"));        } catch (UnsupportedEncodingException e1) {            e1.printStackTrace();        }        byte[] buff = new byte[1024];        BufferedInputStream bis = null;        OutputStream os = null;        try {            os = res.getOutputStream();            bis = new BufferedInputStream(new FileInputStream(excelFile));            int i = bis.read(buff);            while (i != -1) {                os.write(buff, 0, buff.length);                os.flush();                i = bis.read(buff);            }        }catch (Exception e){            e.printStackTrace();        }finally {            if (bis != null) {                try {                    bis.close();                } catch (IOException e) {                    e.printStackTrace();                }            }        }    }

前端伪代码结合Axios(核心代码一样,只是结合了Axios)

   Axios({ // 用axios发送post请求                method: 'post',                url: 'http://127.0.0.1:8762/dataService/download', // 请求地址                data: formData, // 参数                responseType: 'blob' // 表明返回服务器返回的数据类型            })                .then((res) => { // 处理返回的文件流                    let blob = new Blob([res.data], {type: res.data.type})                    const fileName = 'ProductTemplateCopy.xlsx';                    let downloadElement = document.createElement('a')                    let href = window.URL.createObjectURL(blob); //创建下载的链接                    downloadElement.href = href;                    downloadElement.download = fileName; //下载后文件名                    document.body.appendChild(downloadElement);                    downloadElement.click(); //点击下载                    document.body.removeChild(downloadElement); //下载完成移除元素                    window.URL.revokeObjectURL(href); //释放blob                    message.success('upload successfully.');            })            .catch(function (error) {                console.log(error);            });

SpringBoot文件下载的几种方式

1. 将文件以流的形式一次性读取到内存

通过响应输出流输出到前端

@RequestMapping("/download")public void download(String path, HttpServletResponse response) {    try {        // path是指想要下载的文件的路径        File file = new File(path);        log.info(file.getPath());        // 获取文件名        String filename = file.getName();        // 获取文件后缀名        String ext = filename.substring(filename.lastIndexOf(".") + 1).toLowerCase();        log.info("文件后缀名:" + ext);        // 将文件写入输入流        FileInputStream fileInputStream = new FileInputStream(file);        InputStream fis = new BufferedInputStream(fileInputStream);        byte[] buffer = new byte[fis.available()];        fis.read(buffer);        fis.close();        // 清空response        response.reset();        // 设置response的Header        response.setCharacterEncoding("UTF-8");        //Content-Disposition的作用:告知浏览器以何种方式显示响应返回的文件,用浏览器打开还是以附件的形式下载到本地保存        //attachment表示以附件方式下载   inline表示在线打开   "Content-Disposition: inline; filename=文件名.mp3"        // filename表示文件的默认名称,因为网络传输只支持URL编码的相关支付,因此需要将文件名URL编码后进行传输,前端收到后需要反编码才能获取到真正的名称        response.addHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(filename, "UTF-8"));        // 告知浏览器文件的大小        response.addHeader("Content-Length", "" + file.length());        OutputStream outputStream = new BufferedOutputStream(response.getOutputStream());        response.setContentType("application/octet-stream");        outputStream.write(buffer);        outputStream.flush();    } catch (IOException ex) {        ex.printStackTrace();    }}

2. 将输入流中的数据循环写入到响应输出流中

而不是一次性读取到内存,通过响应输出流输出到前端

@RequestMapping("/downloadLocal")public void downloadLocal(String path, HttpServletResponse response) throws IOException {   // 读到流中   InputStream inputStream = new FileInputStream(path);// 文件的存放路径   response.reset();   response.setContentType("application/octet-stream");   String filename = new File(path).getName();   response.addHeader("Content-Disposition", "attachment; filename=" + URLEncoder.encode(filename, "UTF-8"));   ServletOutputStream outputStream = response.getOutputStream();   byte[] b = new byte[1024];   int len;   //从输入流中读取一定数量的字节,并将其存储在缓冲区字节数组中,读到末尾返回-1   while ((len = inputStream.read(b)) > 0) {       outputStream.write(b, 0, len);   }   inputStream.close();}

3. 下载网络文件到本地

@RequestMapping("/netDownloadLocal")public void downloadNet(String netAddress, String path) throws IOException {  URL url = new URL(netAddress);  URLConnection conn = url.openConnection();  InputStream inputStream = conn.getInputStream();  FileOutputStream fileOutputStream = new FileOutputStream(path);  int bytesum = 0;  int byteread;  byte[] buffer = new byte[1024];  while ((byteread = inputStream.read(buffer)) != -1) {      bytesum += byteread;      System.out.println(bytesum);      fileOutputStream.write(buffer, 0, byteread);  }  fileOutputStream.close();}

4. 网络文件获取到服务器后

经服务器处理后响应给前端

@RequestMapping("/netDownLoadNet")public void netDownLoadNet(String netAddress, String filename, boolean isOnLine, HttpServletResponse response) throws Exception {    URL url = new URL(netAddress);    URLConnection conn = url.openConnection();    InputStream inputStream = conn.getInputStream();    response.reset();    response.setContentType(conn.getContentType());    if (isOnLine) {        // 在线打开方式 文件名应该编码成UTF-8        response.setHeader("Content-Disposition", "inline; filename=" + URLEncoder.encode(filename, "UTF-8"));    } else {        //纯下载方式 文件名应该编码成UTF-8        response.setHeader("Content-Disposition", "attachment; filename=" + URLEncoder.encode(filename, "UTF-8"));    }    byte[] buffer = new byte[1024];    int len;    OutputStream outputStream = response.getOutputStream();    while ((len = inputStream.read(buffer)) > 0) {        outputStream.write(buffer, 0, len);    }    inputStream.close();}

5. 常见异常和问题

(1)响应对象无需通过return返回

Springboot如何导出文件

原因: 响应对象是可以不用作为方法返回值返回的,其在方法执行时已经开始输出,且其无法与@RestController配合,以JSON格式返回给前端

Springboot如何导出文件

Springboot如何导出文件

解决办法: 删除return语句

(2)返回前端的文件名必须进行URL编码

原因: 网络传输只能传输特定的几十个字符,需要将汉字、特殊字符等经过Base64等编码来转化为特定字符,从而进行传输,而不会乱码

URLEncoder.encode(fileName, "UTF-8")
(3)IO流有待学习

1:read() :

从输入流中读取数据的下一个字节,返回0到255范围内的int字节值。如果因为已经到达流末尾而没有可用的字节,则返回-1。在输入数据可用、检测到流末尾或者抛出异常前,此方法一直阻塞。

2:read(byte[] b) :

从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。以整数形式返回实际读取的字节数。在输入数据可用、检测到文件末尾或者抛出异常前,此方法一直阻塞。如果 b 的长度为 0,则不读取任何字节并返回 0;否则,尝试读取至少一个字节。如果因为流位于文件末尾而没有可用的字节,则返回值 -1

以上是“Springboot如何导出文件”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Springboot如何导出文件

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Springboot如何导出文件

这篇文章主要介绍Springboot如何导出文件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!后端代码可以把请求设置为post,我这里是Get @RequestMapping(value = "/download",
2023-06-21

ps如何导出psd文件

本篇内容介绍了“ps如何导出psd文件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!psd文件导出的方法:1、首先选择左上角的“文件”打开。
2023-07-04

mysql如何导出db文件

在MySQL中,可以使用命令行工具或者MySQL Workbench来导出数据库文件。以下是两种常用的方法:使用mysqldump命令:mysqldump -u [username] -p [database_name] > [output
mysql如何导出db文件
2024-03-14

Java SpringBoot集成文件之如何使用POI导出Word文档

这篇文章主要介绍了Java SpringBoot集成文件之如何使用POI导出Word文档,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下
2022-11-13

sqlserver如何导出sql文件

要导出一个SQL文件,你可以使用SQL Server Management Studio(SSMS)或者SQLCMD命令行工具。使用SSMS导出SQL文件的步骤如下:打开SQL Server Management Studio并连接到你要
sqlserver如何导出sql文件
2024-04-09

navicat如何导出sql文件

使用 navicat 导出 sql 文件的步骤:连接到数据库,选择要导出的对象。右键单击并选择“导出”,选择“sql 文件”格式。配置导出选项(如创建表语句、插入数据语句等)。指定导出路径和文件名。单击“导出”完成导出过程。如何使用 Nav
navicat如何导出sql文件
2024-06-13

mastergo如何导出源文件

这篇“mastergo如何导出源文件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“mastergo如何导出源文件”文章吧。m
2023-07-02

mysql文件如何导出来

要将MySQL文件导出到另一个位置或者备份,可以使用以下方法:1. 使用MySQL命令行工具(mysql)导出文件:- 打开终端或命令提示符,并进入MySQL安装目录的bin文件夹。- 运行以下命令导出整个数据库:```mysqldump
2023-08-11

idea如何导出java文件

要导出Java文件,可以按照以下步骤进行操作:1. 打开你所使用的Java开发工具(如Eclipse、IntelliJ IDEA等)。2. 在工具中找到你想要导出的Java文件所在的项目或包。3. 右键点击该文件,并选择“导出”或“导出为文
2023-10-20

ps如何导出pdf格式文件

今天小编给大家分享一下ps如何导出pdf格式文件的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。ps导出pdf格式文件的方法:
2023-07-02

如何把eclipse中的文件导出

要将Eclipse中的文件导出,您可以按照以下步骤进行操作:1. 打开Eclipse,并在导航器视图(Navigator View)中找到您想要导出的文件或文件夹。2. 选择要导出的文件或文件夹,右键单击它们,并选择“导出”(Export)
2023-08-20

如何使用plsql导出dmp文件

要使用PL/SQL导出dmp文件,可以使用Oracle提供的expdp工具。以下是导出dmp文件的简单步骤:使用PL/SQL开启一个新的会话。运行以下命令来导出dmp文件:BEGINDBMS_DATAPUMP.OPEN(operation
如何使用plsql导出dmp文件
2024-04-30

如何导出sql数据库文件

要导出 SQL 数据库文件,可以使用数据库管理工具或命令行工具来执行导出操作。以下是一些常见的方法:1. 使用数据库管理工具:- 打开数据库管理工具,如 MySQL Workbench、phpMyAdmin 或 Navicat。- 连接到目
2023-10-10

如何导出mysql数据库文件

要导出MySQL数据库文件,可以使用命令行工具或者可视化工具来完成。下面分别介绍两种方法:方法一:使用命令行工具导出数据库文件:1. 打开命令行终端或者MySQL命令行窗口。2. 输入以下命令导出整个数据库:```mysqldump -u
2023-09-28

如何使用java导出Excel文件

如何使用java导出Excel文件?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。java导出Excel通用方法的实例详解Java导出Excel通用方法,只需要一
2023-05-31

idea导出的jar文件如何用

要使用一个.idea导出的jar文件,您需要按照以下步骤进行操作:1. 确保您已经安装了Java开发工具包(JDK)。2. 打开命令行界面或终端窗口。3. 使用cd命令切换到包含.jar文件的目录。4. 运行以下命令来执行jar文件:`ja
2023-08-15

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录