编码和解码字符串的差异

时间:2015-07-03 15:25:45

标签: c++ string zlib url-encoding urldecode

我使用zlib压缩来返回一个字符串。

void StatsClientImpl::sendToServer(std::stringstream &sstr) // to include an update interval version
{
    std::string error_msg = "";
    std::stringstream temp(AppState::getPid() + "," + AppState::getInstallOS());
    temp << sstr.str();
    std::string s = zlib_compress(temp.str());
.......

zlib_compress的定义如下:https://panthema.net/2007/0328-ZLibString.html

然后我做了:std::cout << s.size() <<"\n";

字符串的大小显示为18。

然后我做了:

CURL *handle = curl_easy_init();
char* o = curl_easy_escape(handle, s.data(), s.size());
        std::string bin(o);
        std::cout << o <<"\n";
        char* i= curl_easy_unescape(handle, bin.data(), bin.size(), NULL);
        std::string in(i);
        std::cout << i << in.size() <<"\n";

这给了我以下输出:

x%DA%D3%D1%81%80%E2%92%D2%B44%1D%03%00%1BW%03%E5
x??с??Ҵ413
x%DA%D3%D1%81%80%E2%92%D2%B44%1D%03

我将此作为输入字符串传递:

,,,,,,stuff,0

为什么解码和编码的字符串有区别? 我该如何解决这个问题?

1 个答案:

答案 0 :(得分:1)

    std::string in(i);

问题出在这里;这个std::string构造函数需要一个以null结尾的字符串,因此它将数据截断为它找到的第一个0字节(在gzip输出的早期找到)。您想问curl_easy_unescape未转义的数据有多长,并相应地构建in

    int sz=0;
    char* i= curl_easy_unescape(handle, bin.data(), bin.size(), &sz);
    std::string in(i, i+sz);
  

但我有一个问题。为什么这不会发生在bin(o)

因为o指向一个URL编码的字符串,除了终结符之外不包含空字节。