因此尝试同时使用 Protocol Buffers v3 和 Go(两者都是新的)。
example.proto
syntax = "proto3";
package test;
import "google/protobuf/timestamp.proto";
message Metadata {
uint64 userID = 2;
google.protobuf.Timestamp time= 3;
}
//SignOff when user logs out of Glory
message SignOff {
Metadata metadata =1;
}
//SignOn when user logs into Glory
message SignOn {
Metadata metadata =1;
}
message EventWrapper {
oneof event {
SignOff signOff = 1;
SignOn signOn = 2;
}
}
用 protoc
转换并在 Go 中使用
now, _ := ptypes.TimestampProto(time.Now())
event := &pb_test.EventWrapper{
Event: &pb_test.EventWrapper_SignOn{
SignOn: &pb_test.SignOn{
Metadata: &pb_test.Metadata{
UserID: 1234,
Time: now,
},
},
},
}
protoBytes, err := proto.Marshal(event)
if err != nil {
log.Fatal(err)
}
log.Println(len(protoBytes) == 0)
jsonBytes, _ = json.MarshalIndent(event, "", "\t")
log.Println(string(jsonBytes))
输出显示 JSON 正确,但 protobuf 编码的字节数组为空。
{
"Event": {
"SignOn": {
"metadata": {
"userID": 1234,
"time": {
"seconds": 1491143507,
"nanos": 654053400
}
}
}
}
}
目的是让这些(repeated *EventWrapper
)的数组通过 gRPC 沿着线路发送,但目前个别的不起作用。 protobuf Language Guide没有说任何关于不允许的结构。有什么我想念的吗?
最佳答案
Protocol Buffer 文档中没有任何内容表明 oneof
不能是结构,事实上 example为 union
字段生成结构。
我推荐使用 gogo ,我个人曾将其用于以前的商业项目。具体来说,使用 protoc-gen-gogoslick
参见 this section安装必要的包,然后为您的项目运行以下命令
protoc --gogoslick_out=Mgoogle/protobuf/timestamp.proto=github.com/gogo/protobuf/types:. example.proto
关于json - 通过 Go 在 Protocol Buffers v3 的 oneOf 字段中使用结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43169640/