Fix geneation of MD5 on Unicode bug

"Geneate MD5 fom text dialog" has geneated wrong result on non ANSI
character (Unicode text).  This bug is due to wong input data.

Fixes #2743
pull/1410/head^2
Don Ho 2017-01-04 20:31:53 +01:00
parent cad87a0124
commit e838758e9b
1 changed files with 12 additions and 8 deletions

View File

@ -124,11 +124,13 @@ void MD5FromTextDlg::generateMD5()
int len = static_cast<int>(::SendMessage(::GetDlgItem(_hSelf, IDC_MD5_TEXT_EDIT), WM_GETTEXTLENGTH, 0, 0));
if (len)
{
char *text = new char[len + 1];
::GetDlgItemTextA(_hSelf, IDC_MD5_TEXT_EDIT, text, len + 1);
wchar_t *text = new wchar_t[len + 1];
::GetDlgItemText(_hSelf, IDC_MD5_TEXT_EDIT, text, len + 1);
WcharMbcsConvertor *wmc = WcharMbcsConvertor::getInstance();
const char *newText = wmc->wchar2char(text, SC_CP_UTF8);
MD5 md5;
char* md5Result = md5.digestString(text);
char* md5Result = md5.digestString(newText);
::SetDlgItemTextA(_hSelf, IDC_MD5_RESULT_FOMTEXT_EDIT, md5Result);
delete[] text;
@ -144,13 +146,14 @@ void MD5FromTextDlg::generateMD5PerLine()
int len = static_cast<int>(::SendMessage(::GetDlgItem(_hSelf, IDC_MD5_TEXT_EDIT), WM_GETTEXTLENGTH, 0, 0));
if (len)
{
char *text = new char[len + 1];
::GetDlgItemTextA(_hSelf, IDC_MD5_TEXT_EDIT, text, len + 1);
wchar_t *text = new wchar_t[len + 1];
::GetDlgItemText(_hSelf, IDC_MD5_TEXT_EDIT, text, len + 1);
std::stringstream ss(text);
std::string aLine;
std::wstringstream ss(text);
std::wstring aLine;
std::string result;
MD5 md5;
WcharMbcsConvertor *wmc = WcharMbcsConvertor::getInstance();
while (std::getline(ss, aLine))
{
// getline() detect only '\n' but not "\r\n" under windows
@ -162,7 +165,8 @@ void MD5FromTextDlg::generateMD5PerLine()
result += "\r\n";
else
{
char* md5Result = md5.digestString(const_cast<char *>(aLine.c_str()));
const char *newText = wmc->wchar2char(aLine.c_str(), SC_CP_UTF8);
char* md5Result = md5.digestString(newText);
result += md5Result;
result += "\r\n";
}