我想将我的dll注入到64位应用程序中,并尝试使用QueueUserAPC在给定的link中解释的逻辑。我正在为每个API获得成功消息但是当我在ProcessExplorer中看到时,我无法在此过程中看到我的dll。 以下是我的代码:
bool FindProcess(PCWSTR exeName, DWORD& pid, vector<DWORD>& tids) {
auto hSnapshot = ::CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS | TH32CS_SNAPTHREAD, 0);
if (hSnapshot == INVALID_HANDLE_VALUE)
return false;
pid = 0;
PROCESSENTRY32 pe = { sizeof(pe) };
if (::Process32First(hSnapshot, &pe)) {
do {
if (_wcsicmp(pe.szExeFile, exeName) == 0) {
pid = pe.th32ProcessID;
THREADENTRY32 te = { sizeof(te) };
if (::Thread32First(hSnapshot, &te)) {
do {
if (te.th32OwnerProcessID == pid) {
tids.push_back(te.th32ThreadID);
}
} while (::Thread32Next(hSnapshot, &te));
}
break;
}
} while (::Process32Next(hSnapshot, &pe));
}
::CloseHandle(hSnapshot);
return pid > 0 && !tids.empty();}
void main(){
DWORD pid;
vector<DWORD> tids;
if (FindProcess(L"DataGrid.exe", pid, tids))
{
printf("OpenProcess\n");
HANDLE hProcess = ::OpenProcess(PROCESS_VM_WRITE | PROCESS_VM_OPERATION, FALSE, pid);
printf("VirtualAllocEx\n");
auto p = ::VirtualAllocEx(hProcess, nullptr, 1 << 12, MEM_COMMIT | MEM_RESERVE, PAGE_READWRITE);
wchar_t buffer[] = L"C:\\Users\\sbhuma\\Documents\\Visual Studio 2015\\Projects\\GalaxyHook\\Debug\\GalaxyHook.dll";
printf("WriteProcessMemory\n");
::WriteProcessMemory(hProcess, p, buffer, sizeof(buffer), nullptr);
for (const auto& tid : tids)
{
printf("OpenThread\n");
HANDLE hThread = ::OpenThread(THREAD_SET_CONTEXT, FALSE, tid);
if (hThread)
{
printf("GetProcAddress\n");
DWORD word = ::QueueUserAPC((PAPCFUNC)::GetProcAddress(GetModuleHandle(L"kernel32"), "LoadLibraryW"), hThread, (ULONG_PTR)p);
if (word)
{
printf("insdie if\n");
}
printf("End of IF\n");
}
}
printf("VirtualFreeEx\n");
::VirtualFreeEx(hProcess, p, 0, MEM_RELEASE | MEM_DECOMMIT);
}}
任何有关将dll注入64位应用程序的帮助都很有帮助,因为我是这个主题的新手。
此致
Sowmya。
答案 0 :(得分:1)
首先,确保您将注射器应用程序构建为64位。
一个可能的原因是你过早地释放了缓冲区。 QueueUserAPC不等待;它将呼叫排队并立即返回。可以是您的注入器进程结束运行for
循环,调用VirtualFreeEx
,然后您的目标进程接收到APC,尝试加载您的DLL但名称缓冲区已经被释放,因此LoadLibrary失败。要验证,请注释掉对VirtualFreeEx的调用。如果您的DLL加载正常,修复内存泄漏的一种方法是在对QueueUserAPC(),CreateEvent
,OpenEvent
和{{进行任何调用之前使用注入器应用中的命名事件SetEvent
1}}在您注入的DLL的DllMain(DLL_PROCESS_ATTACH)中,CloseHandle
之前的注入器应用程序WaitForSingleObject
,我建议在等待时使用超时VirtualFreeEx
。作为副作用,您的注射器应用程序将能够找到并报告注射是否成功。
另一个可能的原因是您的目标应用永远不会进入警报状态。并非所有应用程序都使用APC,在Windows中实现异步内容有多种替代方法。因此,并非所有应用程序都会调用这些SleepEx / WaitForMultipleObjectsEx函数。这样的应用程序将永远不会收到该APC。如果是这种情况,您应该使用另一种DLL注入方法。 DataGrid.exe名称提示您的目标应用程序可能是一个GUI应用程序。您可以CloseHandle
或EnumWindows
查找其顶级窗口FindWindow
以获取拥有该窗口的线程ID,GetWindowThreadProcessId
将您的DLL注入目标进程。< / p>