base64和file互转
程序员文章站
2022-04-28 21:24:39
...
应用场景
工作中经常遇到需要把图片文件操作之后再上传到服务器(比如,压缩、旋转、拼接、裁剪、生成预览、canvas等),通常操作之后的图片都会变成一个 base64 编码的字符串,把这个字符串嵌入到 img 标签的 src 属性中就能看到图片了。
正常来说也是可以把这个字符串传给服务器存储的,但是图片生成base64字符串后特别特别的长,这样存取的话非常慢。
所以我们需要把它转回成文件对象再传给服务器,这样就能得到一个图片的链接了。
正常我们通过 <input type="file"/>
上传图片得到的file对象是这样的:
通过base64编码之后是这样的:
转换成blob再传给服务器就可以了,图片信息都在里面呢
转换方法
base64 转 blob
function dataURLtoBlob(dataurl) {
var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],
bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
return new Blob([u8arr], { type: mime });
}
blob 转 base64
function blobToDataURL(blob, callback) {
let a = new FileReader();
a.onload = function (e) { callback(e.target.result); }
a.readAsDataURL(blob);
}