protobuf 简介
抓包时看到header中有这个:
content-type: application/x-protobuf
说明包的content是以protobuf格式编码的
关于protobuf的介绍,可以参考:
https://techkranti.com/what-is-protobuf-explained-for-hackers/
protobuf 的背景
“protobuf”代表 Protocol Buffers。Google 在 2001 年创建了这种格式供内部使用,并于 2008 年发布供公众使用。
protobuf的优势:性能和向后兼容性(in case of future schema changes)
protobuf 的效率
按照Google的说法,protobuf 比 XML 快 20 到 100 倍
(参考 https://developers.google.com/protocol-buffers/docs/overview#whynotxml)
protobuf 的解析
整体来说,一段protobuf格式的16进制数据,是没法单独完美解析的,需要使用相应的.proto文件,才能完美解析。
下面说明使用protobuf格式传递数据的过程。
开发者首先需要编写.proto文件,.proto文件的内容示例如下:
然后需要把.proto文件丢给目标语言的protobuf编译器。protobuf编译器将生成相应语言的代码。例如,对Java来说,编译器生成相应的.java文件,以及一个特殊的Builder类(该类用于创建消息类接口)。
protobuf编译器会生成相应的方法,这些方法包括序列化方法和反序列化方法。
- 序列化方法用于创建和操作object,将它们转换为序列化格式,以进行存储或传输。
- 反序列化方法用于将输入的protobuf数据转换为object。
编译器完成它的工作后,开发人员所要做的,就是在发送/接收数据的代码中使用这些方法。