首页 > 后端开发 > Golang > `google/protobuf/struct.proto` 是通过 gRPC 发送动态 JSON 数据的最佳方式吗?

`google/protobuf/struct.proto` 是通过 gRPC 发送动态 JSON 数据的最佳方式吗?

Susan Sarandon
发布: 2024-12-03 15:10:10
原创
635 人浏览过

Is `google/protobuf/struct.proto` the Best Way to Send Dynamic JSON Data via gRPC?

“google/protobuf/struct.proto”是通过 GRPC 传输动态 JSON 的最佳方法吗?

使用 google/protobuf/struct .proto 是通过以下方式传输动态 JSON 对象的有效方法GRPC。

使用 google/protobuf/struct

google/protobuf/struct.proto 提供了一个通用数据结构,用于表示 Protobuf 消息中的 JSON 对象。它包括两种关键消息类型:

  • 值 - 表示单个 JSON 值(例如字符串、数字、列表)
  • 结构 - 表示字段值对的集合

动态JSON

动态 JSON 是指存储为字符串的非结构化或灵活数据。如果您的数据遵循预定义的架构,则定义自定义 Protobuf 消息类型可能会更有效。

Proto 文件

您的原型文件 (User.proto) 使用 google/ protobuf/struct.proto 声明 SendJsonRequest 消息。 Details 字段的类型为 Struct,允许传入动态 JSON 数据。

客户端代码

您的客户端代码使用 structpb 创建 structpb.Struct 的实例.NewStruct(),将map[string]interface{}转换为Struct

替代解决方案

Anuj 的解决方案

此解决方案更为复杂,需要手动将每个映射条目转换为structpb.Value,需要更多代码

Luke 的解决方案

虽然更简洁,但该解决方案仍然涉及从 map 转换为 bytes,然后转换为 structpb.Struct。

来自不同方法的解决方案

建议的解决方案使用structpb.NewStruct() 直接从map创建Struct对象,省去中间转换。

结论

使用 google/protobuf/struct.proto 可以是处理非结构化或灵活数据时通过 GRPC 传输动态 JSON 的合适选项。但是,如果您的数据遵循特定架构,则定义自定义 Protobuf 消息可能会提高效率和类型安全性。

以上是`google/protobuf/struct.proto` 是通过 gRPC 发送动态 JSON 数据的最佳方式吗?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板