我正在编写一个使用 protobuf 作为序列化系统的轻量级服务器客户端系统。我在 protobufs 抱怨缺少必填字段时遇到问题,但 1)这些字段显然存在于数据流中,并且 2)错误消息无法识别缺少的字段。
首先是一些代码:
myMessages::DataRequest cData; // this is declared outside of the function in the global
// so it can be reused each time to avoid unnecessary
// memory allocation. Per the documentation in protobufs
.
.
.
bool processStream(u_int8_t *pStream, u_int32_t dwLength)
{
try
{
if (!cData.ParseFromArray(pStream, dwLength))
{
printf("Failed to parse data stream\n");
hexdump(pStream, dwLength);
return false;
}
}
catch(exception e)
{
printf("Exception in ParseFromArray: %s", e.what());
hexdump(pStream, dwLength);
return false;
}
这是我获取完整数据流并尝试让 protobufs 对其进行解码的代码。大多数情况下,这工作正常。但是通过这段代码的每一次迭代我都会得到这个错误:
[libprotobuf ERROR google/protobuf/message_lite.cc:123] Can't parse message of type "myMessages.DataRequest" because it is missing required fields:
由于失败,我的代码吐出这向我展示了提供给 protobuf 解析器的缓冲区:
Failed to parse data stream
000000: 08 86 ad 80 a5 f0 e7 aa e7 01 12 06 64 37 32 36 ............d726
000010: 31 37
DataRequest .proto 非常简单......
message DataRequest {
required uint64 timeStamp = 1;
required string strid= 2;
optional bool checkin= 3;
// event messages
repeated internalMessage1 iEvents = 5;
repeated internalMessage2 oEvents = 6;
repeated internalMessage3 eEvents = 7;
repeated internalMessage4 qEvents = 8;
// aux messages
repeated auxMessages auxEvents = 20;
}
这个 proto 表明唯一需要的字段是 1 和 2(分别是时间戳和 strid)。解码在 hexdump 中看到的数据的有线格式,您可以清楚地看到两个必填字段都存在。此外,您可以看到缺少重复的字段(所以它不像我在其中一个字段中缺少必填字段!)。
知道为什么 protobufs 在这里是个混蛋吗?
谢谢!
贾克