Blob格式转json格式,拿到后端返回的json数据

简介: 文章介绍了如何将后端返回的Blob格式数据转换为JSON格式,并处理文件下载和错误提示。

Blob格式转json格式,拿到后端返回的json数据

在进行文件下载的时候,我们通过blob,进行下载文件,需要axios设置responseType

responseType: 'blob',
 axios({
   
          ...xxx,
        responseType: 'blob',
    }).then(res => {
   
          if (!res || !res.headers['content-disposition']) {
   
               if (res && res.status === 200 && res.data) {
   

                   //转换步骤
                   const file = new FileReader();
                   file.readAsText(res.data, 'utf-8');
                   file.onload = function () {
   
                       const obj = JSON.parse(file.result);
                       console.log(obj, 'obj')
                       if (obj.code === '10000') {
   
                           message.error(obj.message || '下载失败!')
                       }
                       return obj;//此时message为转化好的json格式
                   }
                   return false


               } else {
   
                   message.error(res.message || '下载失败!')
                   return
               }
           }
           if (res && res.status === 200 && res.data) {
   
               const {
    data, headers } = res
               let fileName
               if (headers['content-disposition']) {
   
                   fileName = headers['content-disposition'].replace(/\w+;filename=(.*)/, '$1')
               } else {
   
                   fileName = data.fileName
               }
               // 此处当返回json文件时需要先对data进行JSON.stringify处理,其他类型文件不用做处理
               const blob = new Blob([data], {
    type: headers['content-type'] })
               const dom = document.createElement('a')
               const downUrl = window.URL.createObjectURL(blob)
               dom.href = downUrl
               dom.download = decodeURIComponent(fileName)
               dom.style.display = 'none'
               document.body.appendChild(dom)
               dom.click()
               dom.parentNode.removeChild(dom)
               window.URL.revokeObjectURL(url)
               return res
           }
           message.error(res.message || '下载失败!')
       })
       .catch(err => {
   
           // error(err || '下载失败!')
           console.log('下载失败')
       })

但是有时候文件过大或者其他原因,后端不让我们下载,会直接返回json,这就恶心,明明要接受blob,又给我个json,
所以就需要进行判断然后转换blob,然后提醒:

正常情况下:
在这里插入图片描述
非正常情况:
在这里插入图片描述

我们需要接收到后转成json:

 //转换步骤
      const file = new FileReader();
       file.readAsText(res.data, 'utf-8');
       file.onload = function () {
   
           const obj = JSON.parse(file.result);
           console.log(obj, 'obj')
           if (obj.code === '10000') {
   
               message.error(obj.message || '下载失败!')
           }
           return obj;//此时message为转化好的json格式
       }

在这里插入图片描述
file.onload方法会自动执行,所以直接在这个里面增加提醒就行。嗯,就这样。

目录
相关文章
|
8天前
|
JSON 前端开发 Java
震惊!图文并茂——Java后端如何响应不同格式的数据给前端(带源码)
文章介绍了Java后端如何使用Spring Boot框架响应不同格式的数据给前端,包括返回静态页面、数据、HTML代码片段、JSON对象、设置状态码和响应的Header。
51 1
震惊!图文并茂——Java后端如何响应不同格式的数据给前端(带源码)
|
1天前
|
JavaScript 前端开发 API
vue获取图片的blob传给django后端
vue获取图片的blob传给django后端
13 4
|
4天前
|
JSON JavaScript API
(API接口系列)商品详情数据封装接口json数据格式分析
在成长的路上,我们都是同行者。这篇关于商品详情API接口的文章,希望能帮助到您。期待与您继续分享更多API接口的知识,请记得关注Anzexi58哦!
|
6天前
|
JSON 前端开发 Java
【Spring】“请求“ 之传递 JSON 数据
【Spring】“请求“ 之传递 JSON 数据
32 2
|
6天前
|
JSON 数据格式
LangChain-20 Document Loader 文件加载 加载MD DOCX EXCEL PPT PDF HTML JSON 等多种文件格式 后续可通过FAISS向量化 增强检索
LangChain-20 Document Loader 文件加载 加载MD DOCX EXCEL PPT PDF HTML JSON 等多种文件格式 后续可通过FAISS向量化 增强检索
18 2
|
7天前
|
JavaScript 前端开发
vue3教程,如何手动获取后端数据(入门到精通3,新人必学篇)
本文提供了一个Vue 3教程,讲解了如何使用axios库手动从后端获取数据,包括安装axios、配置后端访问地址、编写路由地址、发起HTTP请求以及在组件中读取和打印响应数据的步骤。
39 0
vue3教程,如何手动获取后端数据(入门到精通3,新人必学篇)
|
1天前
|
前端开发 Java 数据库
springBoot:template engine&自定义一个mvc&后端给前端传数据&增删改查 (三)
本文介绍了如何自定义一个 MVC 框架,包括后端向前端传递数据、前后端代理配置、实现增删改查功能以及分页查询。详细展示了代码示例,从配置文件到控制器、服务层和数据访问层的实现,帮助开发者快速理解和应用。
|
5天前
|
机器学习/深度学习 JSON JavaScript
LangChain-21 Text Splitters 内容切分器 支持多种格式 HTML JSON md Code(JS/Py/TS/etc) 进行切分并输出 方便将数据进行结构化后检索
LangChain-21 Text Splitters 内容切分器 支持多种格式 HTML JSON md Code(JS/Py/TS/etc) 进行切分并输出 方便将数据进行结构化后检索
10 0
|
6天前
|
JSON JavaScript API
商品详情数据接口解析返回的JSON数据(API接口整套流程)
商品详情数据接口解析返回的JSON数据是API接口使用中的一个重要环节,它涉及从发送请求到接收并处理响应的整个流程。以下是一个完整的API接口使用流程,包括如何解析返回的JSON数据:
|
8天前
|
XML JSON 前端开发
C#使用HttpClient四种请求数据格式:json、表单数据、文件上传、xml格式
C#使用HttpClient四种请求数据格式:json、表单数据、文件上传、xml格式
162 0

热门文章

最新文章