2016-07-26 1 views
1

Я пытаюсь преобразовать base64 в blob, но получил ошибку Uncaught InvalidCharacterError: Не удалось выполнить 'atob' on 'Window': Строка, которую нужно декодировать, неправильно закодирована.Uncaught InvalidCharacterError: не удалось преобразовать в blob из base64 image

Я проверил мои данные изображения base64 здесь http://codebeautify.org/base64-to-image-converter и она работала хорошо, я могу видеть изображение вынесенное в порядке

function b64toBlob(b64Data, contentType, sliceSize) { 
      contentType = contentType || ''; 
      sliceSize = sliceSize || 512; 

      var byteCharacters = atob(b64Data); 
      var byteArrays = []; 

      for (var offset = 0; offset < byteCharacters.length; offset += sliceSize) { 
       var slice = byteCharacters.slice(offset, offset + sliceSize); 

       var byteNumbers = new Array(slice.length); 
       for (var i = 0; i < slice.length; i++) { 
        byteNumbers[i] = slice.charCodeAt(i); 
       } 

       var byteArray = new Uint8Array(byteNumbers); 

       byteArrays.push(byteArray); 
      } 

      var blob = new Blob(byteArrays, {type: contentType}); 
      return blob; 
     } 

     var blob = b64toBlob(base64Data, 'image/jpeg'); 
     console.log(blob) 

https://jsfiddle.net/wfh5fjn9/

ответ

1

Что случилось, что вы держали data:image/jpeg;base64, в строке от base64Data. Вам нужно удалить его и сохранить только строку, которая фактически base64 закодирована для ее работы.

Другими словами,

var base64Data = 'data:image/jpeg;base64,/9j/4AAQSkZJRgABAQ' // truncated 

становится

var base64Data = '/9j/4AAQSkZJRgABAQ' // truncated 

https://jsfiddle.net/wfh5fjn9/1/

+0

вар base64ImageContent = base64.replace (/^данные: изображение \/(PNG | JPG); base64,/, ""); почему это не сработает? –

+0

Потому что это должно быть '(png | jpg | jpeg)' – jperezov

+0

будет ли как gif? –