C++ 如何使用c+;更改应用程序中菜单项控件的标题(该控件不是我的)+;win32 api?
例如,如果我想更改为记事本上“编辑”菜单下的“复制”字符串 我正在努力做到以下几点: 使用enumWindowsProc(运行良好)C++ 如何使用c+;更改应用程序中菜单项控件的标题(该控件不是我的)+;win32 api?,c++,windows,user-interface,C++,Windows,User Interface,例如,如果我想更改为记事本上“编辑”菜单下的“复制”字符串 我正在努力做到以下几点: 使用enumWindowsProc(运行良好) 这里有一个漏洞:1)将目标应用程序重命名为备份名称;2) 使用原始名称打开一个新文件;3) 对于整个文件,读入一些数据;如果数据不是所需的字符串,请将其写入输出文件。4) 否则,请修改字符串,然后将其和其余内容写入新文件。5) 关闭所有文件。此方法是一种黑客攻击,因为它不考虑可执行文件中的任何校验和,也不考虑对搜索文本的修改(例如压缩)。使用十六进制编辑器(一种可
这里有一个漏洞:1)将目标应用程序重命名为备份名称;2) 使用原始名称打开一个新文件;3) 对于整个文件,读入一些数据;如果数据不是所需的字符串,请将其写入输出文件。4) 否则,请修改字符串,然后将其和其余内容写入新文件。5) 关闭所有文件。此方法是一种黑客攻击,因为它不考虑可执行文件中的任何校验和,也不考虑对搜索文本的修改(例如压缩)。使用十六进制编辑器(一种可以编辑二进制文件的工具)可能会加快黑客攻击过程。简短的回答是“你不能”。更长的答案是“大多数事情都是可能的,但你可能必须找到一些新的方法来规避/利用/攻击系统-在正常情况下,一个程序不应该修改另一个”。
BOOL CALLBACK enumWindowsProc(
__in HWND hWnd,
__in LPARAM lParam
) {
int length = ::GetWindowTextLength(hWnd);
if (0 == length) return TRUE;
TCHAR* buffer;
buffer = new TCHAR[length + 1];
memset(buffer, 0, (length + 1) * sizeof(TCHAR));
GetWindowText(hWnd, buffer, length + 1);
wcout << buffer << endl;
wstring s2(buffer);
wstring s3(L"Notepad");
std::string::size_type found = s2.find(s3);
if (found != std::string::npos)
{
EnumChildWindows(hWnd, EnumChildProc, 0);
}
delete[] buffer;
return TRUE;
}
BOOL CALLBACK EnumChildProc(HWND hwnd, LPARAM lParam)
{
int length = ::GetWindowTextLength(hwnd);
if (0 == length) return TRUE;
TCHAR* buffer;
buffer = new TCHAR[length + 1];
memset(buffer, 0, (length + 1) * sizeof(TCHAR));
GetWindowText(hwnd, buffer, length + 1);
OutputDebugString(buffer);
OutputDebugString(L"\n");
EnumChildWindows(hwnd, EnumChildProc, 0);
delete[] buffer;
return TRUE;
}