【发布时间】:2021-09-14 15:23:52
【问题描述】:
我有超过 5MB 的数据需要存储在会话存储中。为此,我使用 pako 来压缩数据。
首先,我们有一个 Angular 应用程序,它从 API 接收数据并将其添加到哈希“cachedLookups”中:
const stringifiedLookups = JSON.stringify(this.cachedLookups)
const compressedLookups = new TextDecoder().decode(pako.deflate(stringifiedLookups));
sessionStorage.setItem(this.sessionStorageKey, compressedLookups);
然后我们在同一个浏览器窗口中有一个 AngularJS 应用程序,它从会话存储中检索此数据:
const compressedLookups = localStorageService.get("cachedLookups");
const compressedLookupsUint8Array = new TextEncoder().encode(compressedLookups);
const stringifiedLookups = pako.inflate(compressedLookupsUint8Array, { to: 'string' });
当我点击 pako.inflate 时,我得到“不正确的标题检查”。我也尝试过 inflateRaw,在这种情况下我得到“无效的存储块长度”。我在这里使用 TextEncoder/Decoder,因为尝试将 Uint8Array 直接存储到 SessionStorage 会强制 SessionStorage 超出其配额,尽管计算的大小低于 5MB。我认为这个问题与 Storage API 是关于存储键值字符串对的事实有关。
【问题讨论】:
-
更多信息:我们从 SessionStorage 正确检索 TextDecoded 数据,当我们通过 TextEncoder 运行它时,它返回一个与原始压缩数据相同的 Uint8Array。如果有人可以帮助解释为什么我可能会得到“不正确的标题检查”,那就太好了。
标签: javascript session-storage pako