1

我在 C++ 中遇到 FindWindow() 函数的问题。我正在使用两个程序——程序 A 和程序 B。两者都是本机代码中的控制台应用程序。程序 A 用值初始化 int i 和 string s。程序 B 使用程序 A 运行时显示的地址从程序 A 的内存中读取它们。目前我只对阅读'i'的值感兴趣。

我无法让 FindWindow() 工作,我不知道为什么:/我没有做过太多的 win32 api 编程,所以我在这个隔间里很新。

方案一:

#include <Windows.h>
#include <string>
#include <iostream>

using namespace std;

int main() {
    SetConsoleTitle(L"PROGRAM_A");

    string s = "Kuken\0";
    int i = 12345;
    char choice;

    int* ptr_i = &i;
    string* ptr_s = &s;

    cout << "ADDRESSES: \n";
    cout << "Int i: " << ptr_i << "\n";
    cout << "String s: " << ptr_s << "\n\n";

    cout << "INITIAL VALUES: \n";
    cout << "Int i: " << i << "\n";
    cout << "String s: " << s << "\n\n";

    cout << "***Read/Modify this process memory with programB and view new values! \n\n";


    while (true) {
        cout << "Print values of i and s? y/n \n";
        cin >> choice;
        switch (choice) {
        case 'y': 
            cout << "i: " << *ptr_i << "\n";
            cout << "s: " << *ptr_s << "\n";
            break;
        default:
        break;
        }

    }

    return 0;
    }

方案 B:

#include <Windows.h>
#include <iostream>
#include <string>



int main() {
    HWND handle_temp;
    unsigned long pid;
    int buffer[1];
    std::wstring name = L"PROGRAM_A";

    int temp;
    int* ptr_i;
    std::string* ptr_s;

    std::cout << "Type the address of i in programA: ";
    std::cin >> std::hex >> temp;
    std::cout << "\n";
    ptr_i = (int*)temp;

    std::cout << "Type the address of s in programA: ";
    std::cin >> std::hex >> temp;
    std::cout << "\n\n";
    ptr_s = (std::string*)temp;

    handle_temp = FindWindow(NULL,name.c_str());
    if (!FindWindow(NULL,name.c_str())) {
        std::cout << "Error: Did not find window \n";
        std::cout << "src: " << ptr_i << "\n";
    }
    GetWindowThreadProcessId(handle_temp,&pid);
    HANDLE handle_prgmA = OpenProcess(PROCESS_VM_READ,0,pid);



    if (ReadProcessMemory(handle_prgmA,ptr_i,&buffer,4,NULL)) {
        std::cout << buffer[0];
    }
    else {
        std::cout << "Could not read memory";

}

CloseHandle(handle_prgmA);

while (true) {
    std::cin >> temp;
}

}
4

2 回答 2

4

这根本无法按照您希望的方式工作。即使 FindWindow 调用会成功:该窗口不是由您的控制台程序创建的。相反,Windows 有一个单独的服务器进程负责创建控制台窗口,以便多个进程可以共享一个控制台窗口。

相反,我建议您允许直接输入进程 ID,例如在从程序管理器获得它之后。如果你真的想通过窗口标题找到一个进程,你需要在进程A中使用CreateWindow 。

编辑:您可以使用EnumProcesses在所有进程的列表中找到您的进程。

于 2010-12-19T19:42:53.913 回答
0

IIRC,FindWindow 需要一个消息循环才能运行。由于控制台窗口没有您控制的消息循环,因此它不起作用。

于 2010-12-19T19:53:58.437 回答