我试图从32位进程向64位Windows进程注入一个存根,然后在x64进程中远程启动一个线程。这造成了一些问题,因为winapi的CreateRemoteThread正在抛出错误代码5,这将转换为ERROR_ACCESS_DENIED,无论我在调用OpenProcess时使用哪个标志。我读到这是因为Windows不允许注入“跨平台”,但我不认为这是问题所在,因为代码注入得很好。
我在调用GetLastError()之后立即使用CreateRemoteThread(),它显示了错误代码5。
我正在为OpenProcess使用这组标志,但没有成功:
PROCESS_CREATE_THREAD | PROCESS_VM_OPERATION | PROCESS_VM_READ | PROCESS_VM_WRITE就像PROCESS_ALL_ACCESS一样。
有人知道是什么导致了这个错误吗?
发布于 2015-12-19 08:45:56
不支持从32位进程(目标进程为64位)调用CreateRemoteThread。您需要从64位进程调用CreateRemoteThread。
发布于 2015-12-19 08:27:51
做不到。您不能在64位进程中运行32位代码,也不能在32位进程中运行64位代码。
解决方案是将注入代码重新构建为64位。
这是故意的。处理器在32位和64位模式下的工作方式并不完全相同,您不能从一种模式切换到另一种模式,然后再切换一次。有几件事大不相同:
void foo(int x, int y)将得到涵盖x和y的64位x。这会影响堆栈上的变量和函数中的其他所有变量的偏移量。还有很多其他的东西也不同,但这些应该足以证明“它不是那样工作的”。
https://stackoverflow.com/questions/34368724
复制相似问题