try something like:
var uploader = $scope.uploader = new FileUploader({ url: '/saveImagePath', autoUpload: false }); angular.element(document.querySelector('#fileInput')).on('change',handleFileSelect); var handleFileSelect=function(evt) { var file=evt.currentTarget.files[0]; var reader = new FileReader(); reader.onload = function (evt) { $scope.$apply(function($scope){ $scope.myImage=evt.target.result; }); }; reader.readAsDataURL(file); };
the bootloader does not support base64 images, so you will need to convert the cropped image from base64 to blob
function base64ToBlob(base64Data, contentType) { contentType = contentType || ''; var sliceSize = 1024; var byteCharacters = atob(base64Data); var bytesLength = byteCharacters.length; var slicesCount = Math.ceil(bytesLength / sliceSize); var byteArrays = new Array(slicesCount); for (var sliceIndex = 0; sliceIndex < slicesCount; ++sliceIndex) { var begin = sliceIndex * sliceSize; var end = Math.min(begin + sliceSize, bytesLength); var bytes = new Array(end - begin); for (var offset = begin, i = 0 ; offset < end; ++i, ++offset) { bytes[i] = byteCharacters[offset].charCodeAt(0); } byteArrays[sliceIndex] = new Uint8Array(bytes); } return new Blob(byteArrays, { type: contentType }); }
you need to manually bind files to the queue as follows:
$scope.submit = function () { var file = base64ToBlob($scope.currentPortfolio.croppedImage.replace('data:image/png;base64,',''), 'image/jpeg'); uploader.addToQueue(file); uploader.uploadAll(); };
on the server side, you received two types of files sent as an HTML file, and another un base64, which is a cropped image.
source share