Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/tfs/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C++ 如何使用c+;更改应用程序中菜单项控件的标题(该控件不是我的)+;win32 api?_C++_Windows_User Interface - Fatal编程技术网

C++ 如何使用c+;更改应用程序中菜单项控件的标题(该控件不是我的)+;win32 api?

C++ 如何使用c+;更改应用程序中菜单项控件的标题(该控件不是我的)+;win32 api?,c++,windows,user-interface,C++,Windows,User Interface,例如,如果我想更改为记事本上“编辑”菜单下的“复制”字符串 我正在努力做到以下几点: 使用enumWindowsProc(运行良好) 这里有一个漏洞:1)将目标应用程序重命名为备份名称;2) 使用原始名称打开一个新文件;3) 对于整个文件,读入一些数据;如果数据不是所需的字符串,请将其写入输出文件。4) 否则,请修改字符串,然后将其和其余内容写入新文件。5) 关闭所有文件。此方法是一种黑客攻击,因为它不考虑可执行文件中的任何校验和,也不考虑对搜索文本的修改(例如压缩)。使用十六进制编辑器(一种可

例如,如果我想更改为记事本上“编辑”菜单下的“复制”字符串

我正在努力做到以下几点:

使用enumWindowsProc(运行良好)


这里有一个漏洞: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;
    
}