1

Adding CropperJS into a nodejs solution, and I'm trying to get the returned Base64 string back into file format. So I can send the file to the upload function.

I can't change any functionality and need to use file type to send as a parameter.

I tried: Creating a blob and passing it -> get an error can't to parse the file.

//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();

How do I convert imgSrc to file to pass into the File upload function?

Dale K
  • 25,246
  • 15
  • 42
  • 71
MrJShaun
  • 25
  • 5
  • check this one: https://stackoverflow.com/questions/21227078/convert-base64-to-image-in-javascript-jquery – Raa Sep 12 '19 at 09:32
  • can you share code snippet? – Sandeep Patel Sep 12 '19 at 09:42
  • @Raa i tried that but got an error when sending it through as a parameter.: angular.js:15567 TypeError: Cannot create a Parse.File with that data. at new s (parse.min.js:13) at Object.upload (FileUploadService.js:6) – MrJShaun Sep 12 '19 at 09:47
  • File.upload(file).then(function (savedFile) { console.log(savedFile); $scope.obj.image = savedFile; $scope.isImageOneUploading = false; $scope.$apply(); – MrJShaun Sep 12 '19 at 09:48

1 Answers1

0

You can use this function to convert Base64 image string to image/file object.

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);
JkAlombro
  • 1,696
  • 1
  • 16
  • 30
  • I tried this and getting angular.js:15567 TypeError: File is not a constructor do i need to add any javascript for this? – MrJShaun Sep 12 '19 at 10:05
  • @MrJShaun nope. It should work as long as you put it in a `.js` file. Where did you put the function btw? – JkAlombro Sep 12 '19 at 10:08
  • Thanks for the feedback , Im putting in a .js file. which contains a controller : angular.module('app') .controller('PlaceCtrl', function ($scope,....) { to get the new croped image data. $scope.imgSrc = $scope.cropperCrop.getCroppedCanvas().toDataURL(); Inserted your function here, and it says File is not a constructor error – MrJShaun Sep 12 '19 at 10:17
  • @MrJShaun here's what you should try. Place the function I've posted outside any controllers/directives/etc. Just put it maybe at the bottom of whatever javascript file you're using. Then call it the way I did. I edited my answer to show you a real working example. Try to run the code snippet and you will see that it indeed outputs an image object. – JkAlombro Sep 12 '19 at 10:21
  • And is `Blob` constructor available? You probably don't need `File` anyway, which is indeed not supported by all legacy browsers. – Kaiido Sep 12 '19 at 10:22
  • @JkAlombro this worked! Thanks so much!! added the code outside the controller and it went through correctly to the mongo db. Thanks you so much! been stuck on this for 4 days now – MrJShaun Sep 12 '19 at 10:33