Go语言 Protobuf动态消息模式验证

7lrncoxx  于 2022-12-07  发布在  Go
关注(0)|答案(1)|浏览(230)

我正在尝试实现数据协定逻辑。我有两个相互交换消息的服务。服务A以某种格式+用于生成它的.proto文件的文件描述符proto发送消息。服务B获得它们两者,消息和文件描述符协议,必须确保消息不会破坏模式定义。到目前为止,我所做的是使用描述符原型创建一个动态消息示例,并尝试将消息解组到动态消息示例中,如果在解组过程中没有发生错误,则视为成功(消息不会破坏模式)。
1.是否可以依赖解组函数来确定消息是否正确?
1.我注意到,即使在发送具有完全不同模式的消息时,解组也会成功。我发现导致解组失败的唯一方法是发送缺少必需字段的proto2消息。那么,是不是每个消息都可以使用完全不同的模式定义来解组呢?

  • 我用的是Go语言的官方protobuf库
yebdmbv4

yebdmbv41#

1.是的,可以使用unmarshal函数来检查你的proto是否有效。
1.不,它不是用来解组任意消息,而是用来解组protobuf消息中的字段。例如,您有一个结构如下的proto消息:

message MyMessage {
    uint64 id = 1;
    string name = 2;
    string surname = 3;
}

如果您的服务器收到只包含idname的消息,并且您的服务器正在尝试解组此消息,则idname字段将被解组,而您的结构中的surname字段将为空。此方法也适用于JSON。

相关问题