被后端坑了,他告诉我接口返回的是二进制流,结果怎么都解析不出来,最后才不断测试,发现他返回给我的是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文件
基础教程推荐
猜你喜欢
- iOS开发使用XML解析网络数据 2022-11-12
- Android开发Compose集成高德地图实例 2023-06-15
- Android实现短信验证码输入框 2023-04-29
- Android Compose自定义TextField实现自定义的输入框 2023-05-13
- iOS中如何判断当前网络环境是2G/3G/4G/5G/WiFi 2023-06-18
- iOS开发 全机型适配解决方法 2023-01-14
- Flutter进阶之实现动画效果(三) 2022-10-28
- iOS Crash常规跟踪方法及Bugly集成运用详细介绍 2023-01-18
- MVVMLight项目Model View结构及全局视图模型注入器 2023-05-07
- IOS获取系统相册中照片的示例代码 2023-01-03