在 XML 文件中,我們有一個表示 PDF 文件的 base64 編碼字符串,其中包含一些表格表示,即類似于此示例。當解碼該 PDF 文檔(例如 this )的 base64 字符串時,我們最終得到一個 66 kB 大小的 PDF 文檔,可以在任何 PDF 查看器中正確打開它。在嘗試使用 TypeScript(在 VSCode 擴展中)解碼相同的 base64 編碼字符串時Buffer,即使用以下函數:function decodeBase64(base64String: string): string { const buf: Buffer = Buffer.from(base64String, "base64"); return buf.toString();}// the base64 encoded string is usually extracted from an XML file directly// for testing purposes we load that base64 encoded string from a local fileconst base64Enc: string = fs.readFileSync(".../base64Enc.txt", "ascii");const base64Decoded: string = decodeBase64(base64Enc);fs.writeFileSync(".../table.pdf", base64Decoded);我們最終得到一個 109 kB 大小的 PDF 和一個無法使用 PDF 查看器打開的文檔。對于一個簡單的 PDF,比如這個,具有像這樣的base64 編碼字符串表示,上面的代碼可以工作,并且可以在任何 PDF 查看器中閱讀 PDF。我還嘗試使用 直接讀取本地存儲的 PDF 文件的 base64 編碼表示const buffer: string | Buffer = fs.readFileSync(".../base64Enc.txt", "base64");雖然也沒有產生有用的東西。即使對這個建議稍作調整,由于atob(...)不存在(建議用 Buffer替換atob),最終代碼如下:const buffer: string = fs.readFileSync(".../base64Enc.txt", "ascii");// atob(...) is not present, other answers suggest to use Buffer for conversionconst binary: string = Buffer.from(buffer, 'base64').toString();const arrayBuffer: ArrayBuffer = new ArrayBuffer(binary.length);const uintArray: Uint8Array = new Uint8Array(arrayBuffer);for (let i: number = 0; i < binary.length; i++) { uintArray[i] = binary.charCodeAt(i);}const decoded: string = Buffer.from(uintArray.buffer).toString();fs.writeFileSync(".../table.pdf", decoded);我不會以可讀的 PDF 結尾。“解碼”table.pdf樣本最終大小為 109 kB。我在這里做錯了什么?如何解碼 table.pdf 示例等 PDF 以獲得可讀的 PDF 文檔,類似于 Notepad++ 提供的功能?
Base64 解碼 Typescript 中嵌入的 PDF
子衿沉夜
2023-04-01 15:37:19