在另一个进程上调用 SetProcessDEPPolicy?

发布于 2024-11-30 20:13:41 字数 164 浏览 2 评论 0原文

一款游戏(具体来说是《模拟人生 3》)的编码很差,让它停止随机崩溃的方法之一是将其添加到 DEP 例外列表中。如果不需要的话,我真的不想这样做,所以我想知道是否有一种方法可以在外部进程上使用 SetProcessDEPPolicy 来禁用它的 DEP?无论如何,我都不是一个出色的程序员,所以您提供的信息越多越好。

A game (Sims 3 to be specific) is poorly coded, and one of the ways to get it to stop randomly crashing is to add it to your DEP exception list. I don't really want to do that if I don't have to, so I was wondering if there was a way to use SetProcessDEPPolicy on an external process to disable DEP on it? I'm not a brilliant programmer by any means, so the more information you can give, the better.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

森末i 2024-12-07 20:13:41

可以通过将线程注入远程进程来做到这一点:

HMODULE hKernel32 = GetModuleHandle("kernel32");
// Procedures in kernel32.dll are loaded at the same address in all processes
// so find the address in our own process, then use it in the target process
FARPROC pSetProcessDEPPolicy = GetProcAddress(hKernel32, "SetProcessDEPPolicy");
HANDLE hThread = CreateRemoteThread(hProcess, NULL, 0, (LPTHREAD_START_ROUTINE)pSetProcessDEPPolicy, 0 /* disable DEP */, 0, NULL);
if (hThread == NULL) {
  // handle/report error
}
WaitForSingleObject(hThread);
CloseHandle(hThread);

但这通常是一个坏主意;进程启动和执行线程注入之间存在一个时间窗口,在此期间启用 DEP,反作弊或 DRM 功能可能会将线程注入视为试图破解程序。简单地设置 DEP 例外列表要可靠得多,并且具有相同的效果。

It is possible to do so by injecting a thread into the remote process:

HMODULE hKernel32 = GetModuleHandle("kernel32");
// Procedures in kernel32.dll are loaded at the same address in all processes
// so find the address in our own process, then use it in the target process
FARPROC pSetProcessDEPPolicy = GetProcAddress(hKernel32, "SetProcessDEPPolicy");
HANDLE hThread = CreateRemoteThread(hProcess, NULL, 0, (LPTHREAD_START_ROUTINE)pSetProcessDEPPolicy, 0 /* disable DEP */, 0, NULL);
if (hThread == NULL) {
  // handle/report error
}
WaitForSingleObject(hThread);
CloseHandle(hThread);

However this is generally a bad idea; there's a time window between when the process starts and when you perform the thread injection during which DEP is enabled, and anti-cheat or DRM functionality might see the thread injection as an attempt to hack the program. It's far more reliable to simply set the DEP exception list, and has the same effect.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文