封狼 2022-10-21 15:48 采纳率: 100%
浏览 43
已结题

前端无法解析blob文件

问题遇到的现象和发生背景
vue+springboot 实现下载功能时,前端没法解析文件,但在浏览器的响应中的数据符合要求
用代码块功能插入代码,请勿粘贴截图

前端:

async downloadR(id){
      request.get('search/downloadR/'+id,
          {responseType: 'blob'}
      ).then((res)=>{
        console.log('文件下载成功');
        const blob = new Blob([res.data]);
        const fileName = id+".R";
        if ('download' in document.createElement('a')) {
          //支持a标签download的浏览器
          const link = document.createElement('a');//创建a标签
          link.download = fileName;//a标签添加属性
          link.style.display = 'none';
          link.href = URL.createObjectURL(blob);
          document.body.appendChild(link);
          link.click();//执行下载
          URL.revokeObjectURL(link.href); //释放url
          document.body.removeChild(link);//释放标签
        } else {
         navigator.msSaveBlob(blob, fileName);
        }
      }).catch((res)=>{
        console.log('文件下载失败');
      });
    },

request

const request=axios.create(
    {
        baseURL:'http://localhost:9090',//全局统一前缀
        timeout:5000
    })

//request拦截器
//可以自请求发送前对请求做一些处理
//比如统一加token,对参数统一加密
request.interceptors.request.use(config=>{
    config.headers['Content-Type']='application/json;charset=utf-8'
    return config;
},error => {
    return Promise.reject(error);
});

运行结果及报错内容

下载后的结果

img

浏览器中响应 也是下载应该的结果

img

  • 写回答

3条回答 默认 最新

  • 崽崽的谷雨 2022-10-21 16:14
    关注

    看看res.data是什么

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 11月5日
  • 已采纳回答 10月28日
  • 创建了问题 10月21日

悬赏问题

  • ¥15 docker 运行OPEN-webui异常
  • ¥15 基于ruoyi后台的小程序是二次开发还是原生开发
  • ¥15 麒麟系统如何删除光盘刻录痕迹
  • ¥15 recipe通过gem协议传的是什么
  • ¥15 TS2307: Cannot find module 'cc'.
  • ¥15 100小时学会sap 书上pp章节5.22,标准成本计算逻辑?
  • ¥50 达梦数据库误删日志文件重做DAMENG01.log启动仍然-712错误
  • ¥15 cellranger化学处理类型报错
  • ¥15 用texstudio插入图片出现下面情况,怎么办
  • ¥15 ubantu 用samba挂载windows的共享文件夹,无法挂载二级目录和修改文件