被后端坑了,他告诉我接口返回的是二进制流,结果怎么都解析不出来,最后才不断测试,发现他返回给我的是base64码。。。一、下载流文件首先,reponseType要设置成 blobrequest({url:url,method:post,data,response...
被后端坑了,他告诉我接口返回的是二进制流,结果怎么都解析不出来,最后才不断测试,发现他返回给我的是base64码。。。
一、下载流文件
首先,reponseType要设置成 blob
request({
url:url,
method:'post',
data,
responseType:'blob‘
})
然后,下载就是一个模拟a标签然后模拟点击的过程
假设返回来的流存放在res中。
const blob = new Blob([res])
const fileName = ‘文件名,带后缀的'
let a = document.createElement('a')
a.download = fileName
a.style.display = 'none'
a.href = URL.createObjectURL(blob)
document.body.appendChild(a)
a.click()
URL.revokeObjectURL(a.href)
document.body.removeChild(a)
二、下载base64为文件
后端返回base64编码的话,不用设置reponseType
直接接受开始用,后缀可以自己设置,不过没啥用,base64原来是啥,就会自动变成啥。
let bstr = atob(base64数据)
let n = bstr.length;
let u8arr = new Uint8Array(n);
while(n--){
u8arr[n] = bstr.charCodeAt(n)
}
let url = new Blob([u8arr],{type:'doc'})//这个type没啥用
let reader = new FileReader();
reader.readAsDataURL(url):
reader.onload=function(e){
let a = document.createElement('a')
a.download = 文件名
a.href = e.target.result;
document.body.appendChild(a)
a.click()
document.body.removeChild(a)
}
编程基础网
本文标题为:axios下载流文件,下载base64文件
基础教程推荐
猜你喜欢
- Android zxing如何识别反转二维码详解 2022-11-08
- iOS微信分享后关闭发送成功提示并返回应用 2023-01-03
- iOS的音频文件的格式转换示例 2023-06-11
- Android自定义悬浮按钮效果 2023-04-22
- iOS对数组进行排序的实例代码 2023-03-16
- iOS统计项目的代码总行数 2022-11-01
- 使用Android Studio创建OpenCV4.1.0 项目的步骤 2023-02-26
- Android自定义view实现圆形进度条效果 2023-05-26
- 以代码实例总结iOS应用开发中数据的存储方式 2022-11-20
- Kotlin的枚举与异常示例详解 2022-12-07
