Pregunta Convertir blob en base64


Este es un fragmento del código que quiero hacer Blob a Base64 cuerda:

Esta parte comentada funciona y que cuando la URL generada por esto se establece en img src, muestra la imagen:

var blob = items[i].getAsFile();
//var URLObj = window.URL || window.webkitURL;
//var source = URLObj.createObjectURL(blob);
//console.log("image source=" + source);

var reader = new FileReader();
reader.onload = function(event){
console.log(event.target.result)
}; // data url!
var source = reader.readAsBinaryString(blob);

El problema es con el código más bajo, la variable fuente generada es nula

Actualizar: 

¿Hay alguna manera más fácil de hacer esto con JQuery para poder crear el archivo Base64 String from Blob como en el código anterior?


74
2017-09-06 04:55


origen


Respuestas:


 var reader = new FileReader();
 reader.readAsDataURL(blob); 
 reader.onloadend = function() {
     base64data = reader.result;                
     console.log(base64data);
 }

Forma el documentos  readAsDataURL codifica a base64


146
2017-09-06 05:05



esto funcionó para mí:

var blobToBase64 = function(blob, cb) {
    var reader = new FileReader();
    reader.onload = function() {
    var dataUrl = reader.result;
    var base64 = dataUrl.split(',')[1];
    cb(base64);
    };
    reader.readAsDataURL(blob);
};

10
2017-10-27 16:19



Entonces, el problema es que quieres subir una imagen base 64 y tienes una url blob. Ahora la respuesta que funcionará en todos los navegadores html 5 es: Hacer:

  var fileInput = document.getElementById('myFileInputTag');
  var preview = document.getElementById('myImgTag');

  fileInput.addEventListener('change', function (e) {
      var url = URL.createObjectURL(e.target.files[0]);
      preview.setAttribute('src', url);
  });
function Upload()
{
     // preview can be image object or image element
     var myCanvas = document.getElementById('MyCanvas');
     var ctx = myCanvas.getContext('2d');
     ctx.drawImage(preview, 0,0);
     var base64Str = myCanvas.toDataURL();
     $.ajax({
         url: '/PathToServer',
         method: 'POST',
         data: {
             imageString: base64Str
         },
     success: function(data) { if(data && data.Success) {}},
     error: function(a,b,c){alert(c);}
     });
 }

3
2018-02-04 08:50



puedes arreglar el problema de la siguiente manera:

var canvas = $('#canvas'); 
var b64Text = canvas.toDataURL();
b64Text = b64Text.replace('data:image/png;base64,','');
var base64Data = b64Text;

Espero que esto te ayude


2
2017-12-15 12:36



var audioURL = window.URL.createObjectURL(blob);
        audio.src = audioURL;

var reader = new window.FileReader();
        reader.readAsDataURL(blob);
        reader.onloadend = function () {
            base64data = reader.result;
            console.log(base64data);
        }

2
2018-02-02 15:16



La forma más fácil en una sola línea de código 

var base64Image = new Buffer (blob, 'binary') .toString ('base64');


0
2018-04-04 13:06