axios获得文件流,转为blob,出现部分文件乱码问题解决思路

一、 什么是blob?

blob对象表示一个不可变、原始数据的类文件对象。blob文档
Blob表示的不一定是JavaScript原生格式的数据。
File接口基于Blob,继承了blob的功能并将其扩展使其支持用户系统上的文件。
Blob()构造函数返回一个新的Blob对象。blob的内容由参数数组中给出的值的串联组成。

二、前后端如何进行文件传输?

前后端分离,文件是通过文件流的形式进行传输的,前端通过axios请求后端接口,得到的响应数据是一串字符串。
js中有个Blob对象,一个 Blob对象表示一个不可变的, 原始数据的类似文件对象。Blob表示的数据不一定是一个JavaScript原生格式 blob对象本质上是js中的一个对象,里面可以储存大量的二进制编码格式的数据。
所以,前端可以通过创建blob去接收文件流

三、预览pdf出现乱码

问题: 使用blob对象去预览pdf,大部分文件可以正常预览,少部分出现乱码,查阅资料发现要加语句responseType: 'blob', 但主要的问题是功能能正常使用,少部分出现问题。通过问后端,后端说他那边没有问题,那问题是不是出现在文件上?然而文件并没有问题,是文件大小的原因嘛?通过验证发现文件大小更大的都能正常使用。
于是,开始阅读前端代码:
在这里插入图片描述
axioas能正常发出请求并得到响应结果,我将响应结果打印出来,发现返回结果是正确的,仔细一看,blob中的type与实际文档类型不一致。我是用后端提供的json数据进行判断的,刚好有几条没有后缀名。 于是,我以为是后端给的数据出现问题,然而…

在这里插入图片描述

四、从消息头中获取文件类型

原来,response的header里面包含了文件名以及文件类型,直接从里面拿就行了,这样就可以保证不出错了:
在这里插入图片描述

五、http中使用MIME类型表示响应数据类型
1、什么是Content-type

要知道什么是Content-Type,首先要了解什么是Internet Media Type。Internet Media Type即互联网媒体类型,也叫做MIME类型,使用两部分标识符来确定一个类型。在HTTP协议消息头中,使用Content-Type来表示具体请求中的媒体类型信息,意思就是说,Content-Type是Internet Media Type在HTTP协议中的别称。
content-type可以分为主类型、子类型和参数三大类
如:
multipart/form-data : 需要在表单中进行文件上传时,就需要使用该格式
参考链接

记录在实习过程中遇到的一些问题以及解决思路

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: axios是一个基于Promise的HTTP客户端库,支持在浏览器和Node.js中发送HTTP请求。当使用axios下载文件时,如果需要指定响应的数据类型为blob,则可以使用responseType配置选项。 在使用responseType为blob时,如果后端出现错误,可以通过catch捕获错误信息并处理。例如: ```javascript axios({ method: 'get', url: '/download/file', responseType: 'blob' }).then((response) => { // 处理下载的文件 }).catch((error) => { // 处理捕获到的错误信息 }); ``` 在上述代码中,当后端出现错误时,会触发catch块中的代码,可以在这里处理错误信息,例如提示用户下载失败或重新尝试下载等操作。 ### 回答2: 在使用axios进行文件下载请求时,我们可以通过设置responseType为blob来获取文件的二进制数据。然而,当后端返回的数据不是预期的文件类型时,可能会出现错误。为了捕获后端错误问题,我们可以使用try-catch语句来处理异常。 首先,我们需要设置axios的响应拦截器,用于在请求返回时捕获错误。在拦截器中,我们将判断返回数据的类型,如果不是预期的blob类型,则抛出一个自定义的错误。 ```javascript axios.interceptors.response.use( response => { if (response.config.responseType === 'blob' && response.data.type !== 'application/octet-stream') { throw new Error('后端返回数据异常') } return response }, error => { return Promise.reject(error) } ) ``` 接下来,在发起文件下载请求时,我们可以使用try-catch语句来包裹axios请求,并处理可能抛出的错误。 ```javascript try { const response = await axios.get('/download', { responseType: 'blob' }) // 文件下载成功的逻辑处理 } catch (error) { // 捕获并处理后端错误 console.error(error.message) } ``` 这样,当后端返回的数据不是预期的blob类型时,我们就可以捕获到错误,并进行相应的处理,例如输出错误信息到控制台。 注意,由于axios是基于Promise的异步请求库,我们使用了async/await来进行异步处理。当然,你也可以使用.then()来处理异步请求。以上代码只是一个简单示例,你可以根据自己的需求进行进一步的优化和处理。 ### 回答3: 在使用axios进行文件下载请求时,可以设置responseType为blob来获取二进制数据作为响应。但是在这种情况下,由于后端错误的情况下,返回的响应数据类型可能依然是blob,而不是正常的json数据。因此,需要在前端代码中进行相应的处理来捕获后端错误。 首先,在axios请求中设置responseType为blob: ```javascript axios.get(url, { responseType: 'blob' }) ``` 之后,在返回的响应中,可以通过判断响应的Content-Type来确定响应数据类型。如果是对应的错误类型,则可以通过读取blob数据并进行相应的处理。 ```javascript axios.get(url, { responseType: 'blob' }).then(response => { const contentType = response.headers['content-type']; if (contentType === 'application/json') { // 正常情况 // 处理响应数据 } else { // 错误情况 response.blob().then(blobData => { // 处理错误数据 }); } }).catch(error => { // 请求错误 console.error(error); }); ``` 在错误情况下,使用response.blob()将blob数据转换为对应的Blob对象,并可以进行进一步的操作。比如,可以读取该Blob对象中的错误信息,并根据具体情况进行相应的处理,比如提示错误信息给用户或者进行其他的业务操作。 需要注意的是,设置responseType为blob时,后端返回的响应必须包含相应的Content-Type头部信息,以便前端能正确判断响应数据类型。否则,需要与后端进行沟通,确保正确返回对应的Content-Type信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值