反调试 - WUDFPlatform.dll 导出函数

在 C:\Windows\System32 目录下有一个 WUDFPlatform.dll , 这个 dll 中有三个导出函数 —— WudfIsAnyDebuggerPresent,WudfIsKernelDebuggerPresent,WudfIsUserDebuggerPresent:
在这里插入图片描述代码示例:

// Test_Console_1.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <iostream>
#include <Windows.h>

using namespace std;

typedef INT(NTAPI* pWudfIsAnyDebuggerPresent)();
typedef INT(NTAPI* pWudfIsKernelDebuggerPresent)();
typedef INT(NTAPI* pWudfIsUserDebuggerPresent)();

int main()
{
    HMODULE h_wudf = LoadLibrary(L"WUDFPlatform.dll");
    if (h_wudf == NULL) {
        cout << "WUDFPlatform.dll LoadLibrary failed." << endl;
        goto main_end;
    }

    // WudfIsAnyDebuggerPresent
    pWudfIsAnyDebuggerPresent WudfIsAnyDebuggerPresent = (pWudfIsAnyDebuggerPresent)GetProcAddress(h_wudf, "WudfIsAnyDebuggerPresent");
    if (WudfIsAnyDebuggerPresent == NULL) {
        cout << "WudfIsAnyDebuggerPresent GetProcAddress failed." << endl;
        goto main_end;
    }
    if (WudfIsAnyDebuggerPresent() != 0) {
        cout << "WudfIsAnyDebuggerPresent 发现调试器" << endl;
    }
    
    // WudfIsKernelDebuggerPresent
    pWudfIsKernelDebuggerPresent WudfIsKernelDebuggerPresent = (pWudfIsKernelDebuggerPresent)GetProcAddress(h_wudf, "WudfIsKernelDebuggerPresent");
    if (WudfIsKernelDebuggerPresent == NULL) {
        cout << "WudfIsKernelDebuggerPresent GetProcAddress failed." << endl;
        goto main_end;
    }
    if (WudfIsKernelDebuggerPresent() != 0) {
        cout << "WudfIsKernelDebuggerPresent 发现调试器" << endl;
    }

    // pWudfIsUserDebuggerPresent
    pWudfIsUserDebuggerPresent WudfIsUserDebuggerPresent = (pWudfIsUserDebuggerPresent)GetProcAddress(h_wudf, "WudfIsUserDebuggerPresent");
    if (WudfIsUserDebuggerPresent == NULL) {
        cout << "WudfIsUserDebuggerPresent GetProcAddress failed." << endl;
        goto main_end;
    }
    if (WudfIsUserDebuggerPresent() != 0) {
        cout << "WudfIsUserDebuggerPresent 发现调试器" << endl;
    }

main_end:
    getchar();
    return 0;
}

效果图:
(1)正常情况下运行
在这里插入图片描述

(2)使用 VS 调试运行
在这里插入图片描述

(3) 放在双机调试的虚拟机里运行
在这里插入图片描述

特别注意,该功能只支持 x64程序

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值