vue 后端返回文件流,前端导出下载

文章讲述了在Vue应用中,如何通过axios的响应拦截器处理后端返回的文件流,并利用Blob和不同的下载策略实现文件下载功能,包括IE和非IE浏览器的兼容处理。

vue 后端返回文件流,前端导出下载

  1. 配置axios响应拦截器
request.interceptors.response.use(
  (response) => {
    const res = response.data
    // 关键代码: 返回的是文件流
    if (res instanceof Blob) {
      return response
    }

    if (res.code == 200 || res == true) {
      return res
    } else {
      Message.error("连接超时")
      return Promise.reject(res)
    }
  },
  (error) => {
    return Promise.reject(error)
  }
)
  1. 配置api响应类型
export async function fileExport(params) {
  return request({
    url: "/api/file/export",
    method: "post",
    data: params,
    responseType: 'blob', // 配置响应类型
    headers: {
      'Content-Type': 'multipart/form-data'
    }
  });
}
  1. 封装解码下载的方法
downloadFile(res) {
  const fileNames = res.headers["content-disposition"];
  if (fileNames) {
    //解码
    const fileName = decodeURIComponent(fileNames.match(/=(.*)$/)[1]);
    // 处理返回的文件流
    const content = res.data;
    const blob = new Blob([content], {
      type: "application/octet-stream; charset=utf-8",
    });
    if ("download" in document.createElement("a")) {
      //非IE下载
      const a = document.createElement("a"); //创建一个a标签
      a.download = fileName; //指定文件名称
      a.style.display = "none"; //页面隐藏
      a.href = URL.createObjectURL(blob); // href用于下载地址
      document.body.appendChild(a); //插到页面上
      a.click(); //通过点击触发
      URL.revokeObjectURL(a.href); //释放URL 对象
      document.body.removeChild(a); //删掉a标签
      this.$message.success("下载成功");
    } else {
      //IE10 + 下载
      navigator.msSaveBlob(blob, fileName);
      this.$message.success("下载成功");
    }
  }
},
  1. 发起下载请求
fileExport({}).then((res) => {
  // 下载文件
  this.downloadFile(res);
}).catch((err) => {});
  1. 后端返回的内容示例
PK-q�cfgfW�d�q�ZCB|��|**h㻆},^{Va�^K<46NXQ�dž�9!P��$��҆�d�c�D�j);��ѝP�g��EM'O�ʕ����H7L�h���R���G��^�'{��zސʮB��3�˙��h.�h�W�жF�j娄CQՠ똈���}ιLU:D�����%އ����,B���[�	�� ;˱�	�{N��~��X�p�ykOL��kN�V��ܿBZ~����q�� �ar��{OPKz��q;S��M~s+q�~>�y�ƹXp`=G��C�q-rh?�ڏ�v��=��_M���5o]���2�`g�	��bb48G_��PKMMr�
前端Vue接收后端返回的流并进行下载,可按以下步骤实现: ### 1. 配置API接口 在导出接口文件里,设置 `responseType` 为 `blob`,以确保接收的数据为二进制大对象。例如车辆运行分析导出的接口配置如下: ```javascript import request from '@/utils/request'; // 车辆运行分析导出 export function exportCarRunAnalyse(data) { return request({ responseType: 'blob', // 重点,responseType设置为 blob url: '/statistics/exportCarRunAnalyse', method: 'post', data }); } ``` 此代码通过 `request` 函数发起请求,指定响应类型为 `blob`,请求的URL为 `/statistics/exportCarRunAnalyse`,请求方法为 `post`,并传递数据 `data` [^5]。 ### 2. 编写下载逻辑 在调取该接口的页面里,处理响应数据并创建下载链接,实现文件下载。示例代码如下: ```javascript // data 为 向后台传递的参数,大家自行定义 exportCarRunAnalyse(data).then(res => { console.log(res); // 控制台输出:Blob {size: 30208, type: 'application/x-msdownload'} var debug = res; if (debug) { var elink = document.createElement('a'); elink.download = '导出表格.xls'; elink.style.display = 'none'; var blob = new Blob([debug], { type: 'application/x-msdownload' }); elink.href = URL.createObjectURL(blob); document.body.appendChild(elink); elink.click(); document.body.removeChild(elink); } }); ``` 上述代码先调用 `exportCarRunAnalyse` 接口获取响应数据,若数据存在,则创建一个 `<a>` 元素,设置下载文件名,将响应数据转换为 `Blob` 对象,为 `<a>` 元素的 `href` 属性赋值为 `Blob` 对象的URL,将 `<a>` 元素添加到页面并触发点击事件,最后移除该元素 [^4]。 ### 3. 另一种下载方法示例 以下是另一种实现下载的代码示例,包含API接口和模板下载函数: ```javascript // API接口 export function download(data) { return request({ url: "xxx", methods: "get", params: data, responseType: "blob", // 收到的数据为blob }); } // 模板下载 async loadown(row) { let res = await download({ id: row.id }); if (res) { let blob = new Blob([res], { type: res.type }); let downloadElement = document.createElement("a"); let href = window.URL.createObjectURL(blob); downloadElement.href = href; downloadElement.download = row.mbmc + ".xls"; document.body.appendChild(downloadElement); downloadElement.click(); window.URL.revokeObjectURL(href); } else { this.$message.error(res.msg); } } ``` 此示例中,`download` 函数用于发起请求获取文件流,`loadown` 函数处理响应数据,创建 `Blob` 对象和下载链接,实现文件下载。若响应失败,则显示错误信息 [^2]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

代码工人笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值