协议消息反序列化不当
Improper deserialization of protocol message
我正在 C language 中尝试协议缓冲区序列化和反序列化。
我创建了一条如下所示的 learn.proto 消息,并尝试将一条消息打包到 *uint8_t 中并解压它。
syntax = "proto3";
package learn;
message learnmessage {
enum LearnType {
ZERO = 0;
ONE = 1;
TWO = 2;
THREE = 3;
FOUR = 4;
FIVE = 5;
SIX = 6;
}
LearnType typ = 1;
string text = 2;
}
解包后,无论我将什么打包到原始消息中,都会获得始终为零的枚举值。但是文本字段值在反序列化后仍然正确。
例如,我正在打包枚举 LEARN__LEARNMESSAGE__LEARN_TYPE__THREE
但解包后,它变成了 LEARN__LEARNMESSAGE__LEARN_TYPE__ZERO
我通过gcc -o program mycode.c learn.pb-c.c -lprotobuf-c
编译
谁能帮我找出我犯的错误:
#include <stdio.h>
#include <stdlib.h>
#include "learn.pb-c.h"
int main()
{
Learn__Learnmessage msg = LEARN__LEARNMESSAGE__INIT, *msgCopy;
size_t len;
uint8_t *msgStr;
msg.typ = LEARN__LEARNMESSAGE__LEARN_TYPE__THREE; //corresponds to enum value 3
msg.text = "again";
len = learn__learnmessage__get_packed_size(&msg); //get the length of the uint8_t needed to pack the message
msgStr = malloc(len * sizeof(uint8_t));
learn__learnmessage__pack(&msg, msgStr); //packs the message into msgStr
msgCopy = learn__learnmessage__unpack(NULL, len, msgStr); //unpack the message into msgCopy
printf("Orginal: %d \n", msg.typ); //prints 3 (expected)
printf("Copy: %d \n", msgCopy->typ); //prints 0 (un-expected)
}
生成的C代码中有字段protobuf_c_boolean has_typ;
。将其设置为 1 后,事情开始按预期工作。
所以代码实际上必须是:
msg.typ = LEARN__LEARNMESSAGE__LEARN_TYPE__THREE;
msg.has_typ = 1;
msg.text = "again";
我正在 C language 中尝试协议缓冲区序列化和反序列化。 我创建了一条如下所示的 learn.proto 消息,并尝试将一条消息打包到 *uint8_t 中并解压它。
syntax = "proto3";
package learn;
message learnmessage {
enum LearnType {
ZERO = 0;
ONE = 1;
TWO = 2;
THREE = 3;
FOUR = 4;
FIVE = 5;
SIX = 6;
}
LearnType typ = 1;
string text = 2;
}
解包后,无论我将什么打包到原始消息中,都会获得始终为零的枚举值。但是文本字段值在反序列化后仍然正确。
例如,我正在打包枚举 LEARN__LEARNMESSAGE__LEARN_TYPE__THREE
但解包后,它变成了 LEARN__LEARNMESSAGE__LEARN_TYPE__ZERO
我通过gcc -o program mycode.c learn.pb-c.c -lprotobuf-c
谁能帮我找出我犯的错误:
#include <stdio.h>
#include <stdlib.h>
#include "learn.pb-c.h"
int main()
{
Learn__Learnmessage msg = LEARN__LEARNMESSAGE__INIT, *msgCopy;
size_t len;
uint8_t *msgStr;
msg.typ = LEARN__LEARNMESSAGE__LEARN_TYPE__THREE; //corresponds to enum value 3
msg.text = "again";
len = learn__learnmessage__get_packed_size(&msg); //get the length of the uint8_t needed to pack the message
msgStr = malloc(len * sizeof(uint8_t));
learn__learnmessage__pack(&msg, msgStr); //packs the message into msgStr
msgCopy = learn__learnmessage__unpack(NULL, len, msgStr); //unpack the message into msgCopy
printf("Orginal: %d \n", msg.typ); //prints 3 (expected)
printf("Copy: %d \n", msgCopy->typ); //prints 0 (un-expected)
}
生成的C代码中有字段protobuf_c_boolean has_typ;
。将其设置为 1 后,事情开始按预期工作。
所以代码实际上必须是:
msg.typ = LEARN__LEARNMESSAGE__LEARN_TYPE__THREE;
msg.has_typ = 1;
msg.text = "again";