欢迎访问我的博客,目前从事Machine Learning,欢迎交流

Taro文件上传:Blob Url下载Blob对象本身并通过接口上传到服务器

最近项目的文件上传遇到一个问题,就是Taro的chooseImage传给回调的是一个Blob对象,一般来说,上传控件都会导出Data Url,而Taro给了一个Blob Url,问题在于,我直接令img.src=url,显示图片完全没问题,问题在于,我要实现文件上传,就要拿到Blob本身,而不是一个访问他的句柄或者说链接。这个url我只能在浏览器内部使用,即使你把这串拿到浏览器中访问,也是访问不到的。那么问题变成:1. 拿到blob本身。   2. 转成服务端能接受的格式发过去。

 1. 获取Blob对象本身:

复制代码
 getBlob(url, callback) { 
        var xhr = new XMLHttpRequest()
        xhr.open('GET', url)
        xhr.responseType = 'blob'
        xhr.onload = () => {
            callback(xhr.response)
        }
        xhr.send()
}
复制代码

 

附上一个转换Data Url的链接:

 blobToDataURL(blob, callback) {
        var a = new FileReader();
        a.onload = e => {
            callback(e.target.result);
        }
        a.readAsDataURL(blob);
}

 

2. 上传,我的服务支持二进制流的文件上传

 

复制代码
addSporterModel.imgUpload = async (blob) => {

   const fd = new FormData();
   fd.append('avatar', blob)
   const result = await axios.post(baseUrl + '/uploads', fd, { headers: { 'Content-Type': 'multipart/form-data' } })
   addSporterModel.img = result.data.id
   return result

}
复制代码

 

 

详细了解Blob 

https://juejin.im/post/59e35d0e6fb9a045030f1f35

 

一些工具函数参考:

https://blog.csdn.net/hahahhahahahha123456/article/details/80605836

https://blog.csdn.net/cuixiping/article/details/45932793

posted @   有蚊子  阅读(4524)  评论(2编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· 单线程的Redis速度为什么快?
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
点击右上角即可分享
微信分享提示