我正在生成一个重置链接/令牌,将通过电子邮件发送给客户端,如下所示。
QByteArray token;
token.resize(crypto_pwhash_SALTBYTES);
randombytes_buf(token.data(), crypto_pwhash_SALTBYTES);
QUrlQuery token_url("http://localhost:8080/reset/staff");
token_url.addQueryItem("token", token);
token_url.query(QUrl::FullyEncoded).toUtf8();
这似乎产生了正确的输出:
http://localhost:8080/reset/staff&token=pc%22%EF%BF%BD%C6%9Fsktx%EF%BF%BD!%06t%5C%0B
要根据存储的哈希验证重置请求,我需要令牌QByteArray。
QByteArray path = request.getPath();
qDebug() << path;
QUrlQuery token_url(path);
QString token(token_url.queryItemValue("token"));
qDebug() << token;
qDebug() << QUrl::fromPercentEncoding(path);
包含firefox中粘贴网址的输出是乱码
"/reset/staff&token=pc\"\xEF\xBF\xBD\xC6\x9Fsktx\xEF\xBF\xBD!\x06t\\\x0B"
"pc\"�Ɵsktx�!%06t\\%0B"
"/reset/staff&token=pc\"�Ɵsktx�!\u0006t\\\u000B"
据我所知,我可能正在做一个小狗的无符号字符Converstion。
将QBytearrays传入和传出QUrlQuery的优雅方法是什么?
我见过一些程序员编写自己的URL解析器,但这似乎过多了。
答案 0 :(得分:0)
[已解决]问题出在QtWebApps HttpRequest :: decodeRequestParams() 除了QUrlQuery.query()并没有像你期望的那样安静地运行,因此Url被双重解码。
K.I.S.S手动编码您的网址
sudo passwd root
在接收端
QByteArray url("http://localhost:8080/reset/staff?");
url.append("&token="+token.toPercentEncoding());
qDebug() << url;
如果有人有更优雅的解决方案,我愿意接受改进。