“google/protobuf/struct.proto”是通过 GRPC 传输动态 JSON 的最佳方法吗?
使用 google/protobuf/struct .proto 是通过以下方式传输动态 JSON 对象的有效方法GRPC。
使用 google/protobuf/struct
google/protobuf/struct.proto 提供了一个通用数据结构,用于表示 Protobuf 消息中的 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中文网其他相关文章!