编码和解码字符串的区别
问题描述:
我使用了zlib压缩来返回一个字符串。 https://panthema.net/2007/0328-ZLibString.html编码和解码字符串的区别
然后我做:被限定如
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 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
为什么会出现在解码和编码字符串区别吗? 我该如何解决这个问题?
答
std::string in(i);
问题出在这里;这个std::string
构造函数需要一个以空字符结尾的字符串,因此它将数据截断为它找到的第一个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);
但我有一个question.Why不会发生这种情况在
bin(o)
?
因为o
指向一个URL编码的字符串,它除了终止符以外不包含空字节。救世主!
救主! :)我只需要在服务器端运行一些测试,然后我会接受你的答案! –
但我有一个问题。为什么在'bin(o)'中不会发生这种情况? –
另外,如果我尝试在javascript中解码此字符串,我应该使用哪个函数? –