如何优雅地处理JSON数据类型不确定性下的protobuf反序列化?

如何优雅地处理json数据类型不确定性下的protobuf反序列化?

优雅处理JSON数据类型不确定性下的Protobuf反序列化

本文介绍一种方法,用于处理API返回的JSON数据,这些数据字段类型可能存在变化,并将其反序列化到Protobuf结构体中。 假设API返回的数据结构中,某个字段的值可能是字符串,也可能是数字:

示例1:

{  "data": "data_string"}

登录后复制

示例2:

{  "data": 123}

登录后复制

初始的Protobuf message定义如下:

message Data {  google.protobuf.Any data = 1;}

登录后复制

对应的Go语言结构体:

type Data struct {    // ... (省略其他字段) ...    Data *any.Any `protobuf:"bytes,1,opt,name=data,proto3" json:"data,omitempty"`}

登录后复制

直接使用这种定义无法直接处理JSON数据类型的不确定性。虽然google.protobuf.Any可以容纳不同类型的数据,但需要更精细的控制来实现正确的序列化和反序列化。

更有效的方案:

根据JSON数据的类型信息,定义不同的Protobuf message,并使用google.protobuf.Any来封装这些不同的message。 例如,假设JSON数据结构如下:

{  "type": "info",  "data": { "msg": "some message" }}

登录后复制

{  "type": "error",  "data": { "code": 123, "err": "some error", "reason": "some reason" }}

登录后复制

我们可以这样定义Protobuf message:

message MyData {  string type = 1;  google.protobuf.Any data = 2;}message MyInfoData {  string msg = 1;}message MyErrorData {  int32 code = 1;  string err = 2;  string reason = 3;}

登录后复制

序列化:

根据type字段的值,选择对应的message进行打包,并将其放入google.protobuf.Any中。 例如,使用类似Java的伪代码:

MyErrorData myError = new MyErrorData() { code = 1, err = "", reason = "" };MyData myData = new MyData() { type = "ERROR" };myData.data.pack(myError);

登录后复制

反序列化:

根据type字段的值,选择对应的message进行解包。 这需要在反序列化代码中添加相应的逻辑判断和类型转换。 客户端和服务端需要定义相同的Protobuf message,并遵循相同的类型约定。 这需要在反序列化代码中添加条件判断和类型转换逻辑,根据type字段的值,选择合适的Protobuf message进行解包。

这种方法需要在客户端和服务端都定义相同的Protobuf message,并遵循相同的类型约定。 通过这种方式,可以有效地处理JSON数据类型不确定性,并确保Protobuf反序列化的正确性。

以上就是如何优雅地处理JSON数据类型不确定性下的protobuf反序列化?的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2538535.html

(0)
上一篇 2025年3月6日 00:54:20
下一篇 2025年2月26日 07:22:03

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论