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

前端无法解析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日

悬赏问题

  • ¥20 收一个快手协议下单算法
  • ¥15 求一个图片中的成交量选股公式
  • ¥15 已知正方形内随机生成坐标matlab
  • ¥30 关于#python#的问题:我想要的是这79个大特征对于房屋售价的最大的影响前十名(相关搜索:随机森林)
  • ¥15 使用matlab计算自定义特殊函数的二重积分,改变积分顺序所得的结果不同的问题?
  • ¥15 mysql做碎片化处理老是报错怎么办
  • ¥15 如何正确在vs2010中初始化map对象
  • ¥30 mmdet3d模型部署问题
  • ¥15 comsol仿真反射率、吸收率时峰值位置和深度不对!
  • ¥30 Visual Studio找不到sdk,如何解决?