登录
首页 >  Golang >  Go问答

验证Protobuf中的动态消息模式

来源:stackoverflow

时间:2024-02-18 18:30:15 219浏览 收藏

偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《验证Protobuf中的动态消息模式》,这篇文章主要会讲到等等知识点,不知道大家对其都有多少了解,下面我们就一起来看一吧!当然,非常希望大家能多多评论,给出合理的建议,我们一起学习,一起进步!

问题内容

我正在尝试实现数据契约逻辑。 我有两个服务相互交换消息。 服务 A 以某种格式发送消息 + 用于生成它的 .proto 文件的文件描述符 proto。服务 B 获取消息和文件描述符原型,并且必须确保消息不会破坏架构定义。 到目前为止,我所做的是使用描述符原型创建一个动态消息实例,并尝试将消息解组到动态消息实例中,如果在解组过程中没有发生错误,则视为成功(消息不打破架构)。

  1. 是否可以依靠 unmarshal 函数来确定消息是否正常?
  2. 我注意到,即使我发送具有完全不同模式的消息,解组也会成功。我发现导致解组失败的唯一方法是发送缺少必需字段的 proto2 消息。 那么,每条消息都可以使用完全不同的模式定义进行整理,这是否是有意为之?
  • 我正在使用官方的 Go protobuf 库

正确答案


  1. 是的,可以使用 unmarshal 函数来检查您的原型是否有效。
  2. 不,它不是为了解组任意消息而设计的,而是为了仅解组 protobuf 消息中存在的字段而设计的。例如,您的原始消息的结构如下:
message MyMessage {
    uint64 id = 1;
    string name = 2;
    string surname = 3;
}

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

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>