base64轉(zhuǎn)文件(blob)遇到的一個(gè)問題

在過程中,發(fā)現(xiàn)報(bào)錯(cuò)如下:

failed to execute 'atob' on 'window': the string to be decoded is not correctly encoded.

在Google后,仍然不能解決,~~o(>_<)o ~~

后來在看atob和btoa的demo時(shí)發(fā)現(xiàn)base64字符串僅僅是后面的亂七八糟字符串好嗎,沒有前面的名片。

var str = "Hello World!";
var enc = window.btoa(str);
var dec = window.atob(enc);

var res = "Encoded String: " + enc + "
" + "Decoded String: " + dec;

The result of res will be:

Encoded String: SGVsbG8gV29ybGQh //看這里?。。?!
Decoded String: Hello World!

而圖片的base64是這樣的:

data:image/gif;base64,/9j/4AAQSkZJRgABAQ........

所以只要后面的就可以了:

b64Data.substring(b64Data.indexOf(',') + 1)

base64轉(zhuǎn)換blob函數(shù)

function b64toBlob(b64Data, contentType, sliceSize) {

        contentType = contentType || '';

        sliceSize = sliceSize || 512;



        var byteCharacters = atob(b64Data.substring(b64Data.indexOf(',') + 1));

        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;

      };
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容