我正在尝试实现数据协定逻辑。我有两个相互交换消息的服务。服务A以某种格式+用于生成它的.proto文件的文件描述符proto发送消息。服务B获得它们两者,消息和文件描述符协议,必须确保消息不会破坏模式定义。到目前为止,我所做的是使用描述符原型创建一个动态消息示例,并尝试将消息解组到动态消息示例中,如果在解组过程中没有发生错误,则视为成功(消息不会破坏模式)。
1.是否可以依赖解组函数来确定消息是否正确?
1.我注意到,即使在发送具有完全不同模式的消息时,解组也会成功。我发现导致解组失败的唯一方法是发送缺少必需字段的proto2消息。那么,是不是每个消息都可以使用完全不同的模式定义来解组呢?
- 我用的是Go语言的官方protobuf库
1条答案
按热度按时间yebdmbv41#
1.是的,可以使用unmarshal函数来检查你的proto是否有效。
1.不,它不是用来解组任意消息,而是用来解组protobuf消息中的字段。例如,您有一个结构如下的proto消息:
如果您的服务器收到只包含
id
和name
的消息,并且您的服务器正在尝试解组此消息,则id
和name
字段将被解组,而您的结构中的surname
字段将为空。此方法也适用于JSON。