From 64174491dac84c559db5c48ed850177fa3eb4da0 Mon Sep 17 00:00:00 2001 From: jellybrick Date: Sat, 14 Mar 2020 23:21:30 +0900 Subject: Fix #127, #128 & Code quality improvements It seems that the author of this code misunderstood 'Array of PollOption' as 'PollOption'. --- src/tools/StringTools.cpp | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) (limited to 'src/tools/StringTools.cpp') diff --git a/src/tools/StringTools.cpp b/src/tools/StringTools.cpp index 1246c50..f49a78e 100644 --- a/src/tools/StringTools.cpp +++ b/src/tools/StringTools.cpp @@ -3,6 +3,7 @@ #include #include #include +#include using namespace std; @@ -58,8 +59,13 @@ string generateRandomString(std::size_t length) { static const string chars("qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM1234567890-=[]\\;',./!@#$%^&*()_+{}|:\"<>?`~"); static const std::size_t charsLen = chars.length(); string result; + + random_device randomDevice; + mt19937 randomSeed(randomDevice()); + uniform_int_distribution generator(0, charsLen - 1); + for (std::size_t i = 0; i < length; ++i) { - result += chars[rand() % charsLen]; + result += chars[generator(randomSeed)]; } return result; } @@ -84,8 +90,7 @@ string urlDecode(const string& value) { for (std::size_t i = 0, count = value.length(); i < count; ++i) { const char c = value[i]; if (c == '%') { - int t = 0; - sscanf(value.substr(i + 1, 2).c_str(), "%x", &t); + int t = stoi(value.substr(i + 1, 2), nullptr, 16); result += (char) t; i += 2; } else { -- cgit v1.2.3