javascript - 将 Base64 图像字符串转换回文件以发送到 Parse upload

标签 javascript node.js angularjs

将 CropperJS 添加到 NodeJS 解决方案中,我试图将返回的 Base64 字符串恢复为文件格式。这样我就可以将文件发送到上传功能。

我无法更改任何功能,需要使用文件类型作为参数发送。

我尝试过:创建一个 blob 并传递它 -> 出现错误,无法解析文件。

//this is used to upload the file 
File.upload(file).then(function (savedFile) {


//with the new cropper i get back base64 string from:
$scope.imgSrc = $scope.cropperCrop.getCroppedCanvas().toDataURL();

如何将 imgSrc 转换为文件以传递到文件上传功能?

最佳答案

您可以使用此函数将 Base64 图像字符串转换为图像/文件对象。

function dataURLtoFile(dataurl, filename) {
    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 File([u8arr], filename, {type:mime});
}

//Usage example:
var base64String = ""
var file = dataURLtoFile(base64String, 'filename.png');
console.log(file);

关于javascript - 将 Base64 图像字符串转换回文件以发送到 Parse upload,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57903631/

相关文章:

javascript - 字符串内换行(React Native)

node.js - 在 Node 中使用 pty 和 ssh2 来使用 sudo 执行命令

javascript - 运行minio服务器时不会出现对minio浏览器的更改

javascript - 防止html页面浏览缓存

angularjs - 使用 angularjs 渲染 json 而不是 html

javascript - 重启 css 过渡

javascript - 排序选择选项元素

javascript - Node.js 事件循环阶段

javascript - Node.js/AngularJS : Shrink image files to specific file size

javascript - 在回调和事件之后调用方法