在 Typescript/Angular8 中将 base64 字符串转换为 uint8Array 或 Blob
Converting base64 string to uint8Array or Blob in Typescript/Angular8
我对使用 Base64 编码 string/uint8Array 或 Blob 还很陌生。我正在为我们的 Angular 8 网络应用程序使用来自此 repo https://github.com/intbot/ng2-pdfjs-viewer 的 pdf 查看器库。
我正在发送一个相当大的 Base64 字符串(550KB 到 UI(包含 34 页文本),由 pdf 查看器呈现。
主要问题是它在查看器中只显示 19 个页面。但是,当我使用查看器下载文档时,它包含所有 34 页(通过 MacOS 上的预览应用程序确认)。
我不确定问题出在 pdf 查看器库还是从 Base64 到 uint8Array/Blob 的转换。
这里是UI中的代码,用来转换Base64字符串
dostuff(b64Data){
const byteCharacters = atob(b64Data);
const byteNumbers = new Array(byteCharacters.length);
for (let i = 0; i < byteCharacters.length; i++) {
byteNumbers[i] = byteCharacters.charCodeAt(i);
}
const byteArray = new Uint8Array(byteNumbers);
//const blob = new Blob([byteArray], {type: 'application/pdf'});
//console.log(blob)
return byteArray
}
如有任何帮助,我们将不胜感激。
使用的浏览器:Chrome
已解决。问题在于后端 API 将 PDF 合并在一起。使用 Apache PDFBox 的 pdf 合并实用程序,它接受输入流,合并后的 pdf 文档由 ng2-pdfjs-viewer 库成功呈现。
上面的JS代码没有问题。
我对使用 Base64 编码 string/uint8Array 或 Blob 还很陌生。我正在为我们的 Angular 8 网络应用程序使用来自此 repo https://github.com/intbot/ng2-pdfjs-viewer 的 pdf 查看器库。 我正在发送一个相当大的 Base64 字符串(550KB 到 UI(包含 34 页文本),由 pdf 查看器呈现。
主要问题是它在查看器中只显示 19 个页面。但是,当我使用查看器下载文档时,它包含所有 34 页(通过 MacOS 上的预览应用程序确认)。 我不确定问题出在 pdf 查看器库还是从 Base64 到 uint8Array/Blob 的转换。
这里是UI中的代码,用来转换Base64字符串
dostuff(b64Data){
const byteCharacters = atob(b64Data);
const byteNumbers = new Array(byteCharacters.length);
for (let i = 0; i < byteCharacters.length; i++) {
byteNumbers[i] = byteCharacters.charCodeAt(i);
}
const byteArray = new Uint8Array(byteNumbers);
//const blob = new Blob([byteArray], {type: 'application/pdf'});
//console.log(blob)
return byteArray
}
如有任何帮助,我们将不胜感激。 使用的浏览器:Chrome
已解决。问题在于后端 API 将 PDF 合并在一起。使用 Apache PDFBox 的 pdf 合并实用程序,它接受输入流,合并后的 pdf 文档由 ng2-pdfjs-viewer 库成功呈现。 上面的JS代码没有问题。