直接将char buff [1024] 转化为char* 存入redis中,由于有/0的存在,会出现/0后面的数据被截断丢失的情况。
解决方法如下
先将buffer用base64编码为QString类型,再QString转化为char* 传入redis命令。
获取数据char*执行base64的解码重新获得buffer即可。
bool RedisAccess::SetConnectState(stTest *date)
{
//初始化buffer
char buff[128];
memset(buff, 0, sizeof(char)*128 );
//1.struct stTest data -> buffer
uint length = date->pack(buff);
qDebug() << "stTest data pack's length = " << length ;
//2.buffer -> QByteArray
QByteArray temp_array;
temp_array.resize(sizeof(buff)); //重置数据大小
memcpy(temp_array.data(), &buff, sizeof(buff)); // copy数据 buffer->QByteArray
qDebug() << "QByteArray " << temp_array;
//3.QByteArray -> QString by Base64
QString str_base64 = temp_array.toBase64();
qDebug() << "QString by Base64: " << str_base64;
//4.QString -> char *
char* buff_set;
QByteArray ba = str_base64.toLatin1();
buff_set = ba.data();
//保存char *数据到redis中
char* key = "stTest1";
m_reply = (redisReply*)redisCommand(m_context, "SET %s %s", key, buff_set);
freeReplyObject(m_reply);
qDebug() << "Set finish" << endl;
return true;
}
bool RedisAccess::GetConnectState(stTest *data)
{
char buff_get[128];
memset(buff_get, 0, sizeof(char)*128 );
char* key = "stTest1";
//从redis中恢复数据
m_reply = (redisReply*)redisCommand(m_context, "GET %s", key);
//1.char * -> QString by base64 ignore
//QString str_base64 = m_reply->str;
//2. QString by base64 -> QByteArray
QByteArray temp_array;
temp_array = QByteArray::fromBase64(m_reply->str);
qDebug() << "QByteArray " << temp_array;
//3. QByteArray -> buffer
memcpy(buff_get, temp_array, sizeof(char) * 128);
//4. buffer -> data
int length = data->unpack(buff_get);
qDebug() << "stTest data unpack's length =" << length;
freeReplyObject(m_reply);
return true;
}