8.6 STARTUPINFO
STARTUPINFO 结构体,可以用来指定新进程的主窗口外观风格、背景颜色、标题等信息,也可以用来实现反调试技术。通常情况下,我们可以将STARTUPINFO
结构体中的dwFlags
成员设置为STARTF_DEBUGONLYTHISPROCESS
,以防止调试器附加到当前进程。设置了STARTF_DEBUGONLYTHISPROCESS
后,如果尝试通过调试器附加到该进程,则调试器将直接失败并退出。
程序启动时默认会通过explorer
资源管理器,调用CreateProcess()
函数创建的时候会把STARTUPINFO
结构体中的值设置为0,但如果通过调试器启动程序时该值并不会发生变化,我们可以通过判断结构体中的dwFlags
参数来实现反调试。
#include <Windows.h>
#include <stdio.h>
BOOL IsDebug()
{
STARTUPINFO si = { 0 };
GetStartupInfo(&si);
if (si.dwFlags != 1)
{
return TRUE;
}
return FALSE;
}
int main(int argc, char * argv[])
{
if (IsDebug())
{
printf("[-] 正在被调试 \n");
}
system("pause");
return 0;
}
文章出处:https://www.cnblogs.com/LyShark/p/17731835.html
本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
2021-09-27 Linux 多种方式实现文件共享