C++ 反调试(ZwSetInformationThread)

这个 API 的功能是:如果程序正在被调试,则强制将自己从调试器里分离出来。

代码:

#include "stdafx.h"

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


#pragma region 全局变量 

/*
	ZwSetInformationThread 第二个成员
*/
typedef enum _THREADINFOCLASS {
	ThreadBasicInformation,
	ThreadTimes, 
	ThreadPriority, 
	ThreadBasePriority, 
	ThreadAffinityMask, 
	ThreadImpersonationToken, 
	ThreadDescriptorTableEntry, 
	ThreadEnableAlignmentFaultFixup,
	ThreadEventPair, 
	ThreadQuerySetWin32StartAddress, 
	ThreadZeroTlsCell,
	ThreadPerformanceCount, 
	ThreadAmILastThread, 
	ThreadIdealProcessor, 
	ThreadPriorityBoost, 
	ThreadSetTlsArrayAddress, 
	ThreadIsIoPending, 
	ThreadHideFromDebugger
}THREAD_INFO_CLASS;

#pragma endregion

#pragma region 依赖函数 

/*
	ZwSetInformationThread
*/
typedef NTSTATUS (NTAPI *pZwSetInformationThread)(
	IN HANDLE ThreadHandle,							// 线程对象句柄 
	IN THREAD_INFO_CLASS ThreadInformaitonClass,	// 线程信息类型
	IN PVOID ThreadInformation,						// 线程信息指针
	IN ULONG ThreadInformationLength				// 线程信息大小
);

#pragma endregion

#pragma region 功能函数 
#pragma endregion

int _tmain(int argc, _TCHAR* argv[])
{
	// 获取 ZwSetInformationThread 函数地址
	pZwSetInformationThread ZwSetInformationThread = (pZwSetInformationThread)GetProcAddress(LoadLibrary(L"ntdll.dll"),"ZwSetInformationThread");
	
	// 执行 ZwSetInformationThread 
	ZwSetInformationThread(GetCurrentThread(),ThreadHideFromDebugger,NULL,NULL);

	// 测试 ZwSetInformationThread 的效果
	std::cout << "程序运行到了这里" << std::endl; 

	getchar();
	return 0;
}

效果图:
在 API 执行前下断点程序可以正常断下:
在这里插入图片描述在 API 执行之后下断点无法断下:
在这里插入图片描述

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值