在過程中,發(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;
};