我想在C++上編寫程序,該程序將解碼包含一些URL編碼的Unicode字符的URL編碼的字符串。UrlUnescape()和Unicode字符
#include <windows.h>
#include <string>
#include <shlwapi.h>
#pragma comment(lib, "Shlwapi.lib")
int _tmain(int argc, _TCHAR* argv[])
{
std::wstring test = L"bla+%D0%B1%D0%BB%D0%BE%D1%84+%E6%97%A5%E6%9C%AC%E8%AA%9E";
PWSTR urlencodedStr = const_cast<WCHAR*>(test.c_str());
WCHAR decodedStr[1025];
DWORD size = 1024;
HRESULT hres = UrlUnescape(urlencodedStr, decodedStr, &size, NULL);
if (hres == S_OK)
MessageBox(NULL, decodedStr, L"decoded string", MB_OK);
return 0;
}
我期待在decodedStr獲得L 「喇嘛блоф日本語」。但是我得到了L「bla +блоÑ」+æ-¥æœèèžž「。 我在我的版本中使用unicode字符集。 我在做什麼錯?