尝试使用PID检索进程的运行目录。我正在使用FindWindow()
和GetWindowThreadProcessId()
获取PID,其结果与任务管理器中显示的进程ID相同,因此我认为它是正确的。
使用GetModuleFileNameEx()
时,我得到的似乎是内存地址,而不是生成路径。
auto wnd = FindWindow(nullptr, L"prog");
while (wnd == nullptr)
{
wnd = FindWindow(nullptr, L"prog");
}
TCHAR fBuf[MAX_PATH]; // buffer for path
DWORD procId; // process id
GetWindowThreadProcessId(wnd, &procId); // get process id
std::cout << procId << std::endl; // results in correct pid
auto procHdl = OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ, false, procId); // create handle for process
if (procHdl != NULL) {
if (GetModuleFileNameEx(procHdl, 0, fBuf, MAX_PATH) == 0) {
std::cerr << "Failed to get module filename." << std::endl;
}
else {
std::cout << "Module filename is: " << fBuf << std::endl;
}
CloseHandle(procHdl);
}
示例输出为:
10488
Module filename is: 008CF93C
使用GetProcessImageFileNname()
也有相同的结果。
答案 0 :(得分:1)
要获取程序的目录,请首先使用GetModuleFileNameEx获取程序路径,然后您的目录将从第一个字符开始到找到的最后一个反斜杠。
示例:
程序为:“ C:\ Windows \ notepad.exe”;
目录是:“ C:\ Windows”;
在代码中:
DWORD pid = 104;
CHAR ProgramFile[MAX_PATH];
std::string DirectoryPath;
HANDLE hProcess = OpenProcess(PROCESS_VM_READ|PROCESS_QUERY_INFORMATION, FALSE, pid);
GetModuleFileNameExA(hProcess, NULL, ProgramFile, MAX_PATH);
DirectoryPath = ProgramFile;
DirectoryPath = DirectoryPath.substr(0, DirectoryPath.find_last_of('\\'));
std::cout << "ProgramFile: " << ProgramFile << endl;
std::cout << "Directory: " << DirectoryPath.c_str();