文件下载的时候 给的是数据流 转换blob 下载 (亲测有效)

文件下载的时候 后台返回数据流 转换blob 下载 (亲测有效)

1.数据流 只需要在router 里面添加一个 responseType格式
downloadArchiveData(params) {  
  return myAxios({
    method: 'post',
    url: '/olap-apply/caseArchive/downloadArchiveData',
    params: params,
    responseType: 'blob'   (只需要在这添加一个格式)
  })
},
下面代码可直接使用
let data = res.data
let url = window.URL.createObjectURL(new Blob([data]))
let link = document.createElement('a')
link.style.display = 'none'
link.href = url
link.setAttribute('download', '下载.zip')  (下载什么格式 更改什么格式,后面是下载出来的名字)
document.body.appendChild(link)
link.click()
2.后台返回的是二进制的数据流 因为是统一封装的 从新写了个axios请求
 import axios from 'axios'
 import {StorageService} from '~/utils/storage.service';
 
   private toDownload(row) {
      const params = {
        fileid: row.logFileId
      }
      let processUrl = require(`../../../environment/${process.env.BUILD_ENV}.env.js`);
      let download = JSON.parse(processUrl.URL.SERVER);

      axios({
        headers: {
          'x-cf-antifraud-prod-token': StorageService.getItem('userToken')
        },
        method: 'get',
        url: download + '/domain-service/api/taskBoxController/downloadFile',
        responseType: 'json',
        params: {
          fileid: row.logFileId
        }
      }).then((res) => {
        /* 兼容正常浏览器和IE */
        //将base64转换为blob
        let bstr = atob(res.data.data);
        let n = bstr.length;
        let u8arr = new Uint8Array(n);
        while (n--) {
          u8arr[n] = bstr.charCodeAt(n);
        }

        let bl = new Blob([u8arr], {type: res.headers['content-type']});
        let url = URL.createObjectURL(bl);
        let a = document.createElement("a");
        a.href = url;
        a.download = res.data.fileName;
        a.click();
        window.URL.revokeObjectURL(url);


      })
      // this.taskBoxervice.downloadFile(params).subscribe((res) => {})
    }
    ```
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值