protobuf.js浏览器encode后得到uint8array,转化成的arraybuffer达到8192bytes

发布于 2022-09-05 08:02:32 字数 916 浏览 21 评论 0

1.场景:利用protobuf.js库来对protocol buffer进行操作。
2.

  1. 首先是我的test.proto文件,用的是第三版的写法
    clipboard.png

  2. 读取proto文件的那些都已经操作好没有问题。

  3. encode函数,对自定义的object进行编码。在浏览器端得到的是一个Uint8Array的数组
    clipboard.pngclipboard.png

  4. 在浏览器下输出结果可以看到,得到的是一个只有11个字节的Uint8Array数组,但是转化成ArrayBuffer之后就变成了8192bytes
    clipboard.png

  5. 查阅了文档以及很多资料都没有结果,有dalao知道是什么情况吗……

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

等数载,海棠开 2022-09-12 08:02:32

遇到了同样的问题,研究了下,这样做即可
uint8.buffer.slice(uint8.byteOffset, uint8.byteOffset + uint8.byteLength);

森林迷了鹿 2022-09-12 08:02:32

请问楼主解决了吗?

晨与橙与城 2022-09-12 08:02:32

把 Uint8Array 转成 ArrayBuffer,除非是传送通道不支持Uint8Array的时候(例如Kafka)才需要这么做。

转换: arrayBuffer = Buffer.from(unit8Array.buffer)

一般情况encode得到Uint8Array之后直接向后传。后面结收到之后直接decode只用。

中间尽量不要做数据转换操作,因为转换太多,pb的序列化/反序列化速度快的优势就不存在了。

奶气 2022-09-12 08:02:32

uint8.slice().buffer 发送给后端即可,slice() 方法会 byteLength 自动截取有效的部分,也就是实际需要的数据。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文