我需要将base64字符串解码为PDF文件。我正在使用此代码。但是window.atob命令始终报告该错误:无法在“窗口”上执行“ atob”:要解码的字符串未正确编码。
我知道该文件是正确的,因为我已经使用将base64解码为pdf的网站对其进行了解码。 我不知道是否有帮助,但是我们正在使用Aurelia Framework。
转换功能
function converBase64toBlob(content, contentType) {
contentType = contentType || '';
var sliceSize = 512;
var byteCharacters = window.atob(content); //method which converts base64 to binary
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
}); //statement which creates the blob
return blob;
}
该函数的调用
self.blob = self.converBase64toBlob(result.contents[0].pdf.replace(/^[^,]+,/, ''), 'application/pdf');
self.blobURL = URL.createObjectURL(blob);
window.open(this.blobURL);
答案 0 :(得分:1)
我找到了解决方案。 Api返回带有字符'\'的base64字符串。因此,我删除了所有内容,并且一切正常。