加入收藏 | 设为首页 | 会员中心 | 我要投稿 西安站长网 (https://www.029zz.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 建站 > 正文

26种对付反调试的方法

发布时间:2019-03-22 04:10:04 所属栏目:建站 来源:luochicun
导读:副标题#e# 目前主要有3种分析软件的方法: 1.数据交换分析,研究人员使用数据包嗅探工具来分析网络数据交换。 2.对软件的二进制代码进行反汇编,然后以汇编语言列出。 3.字节码解码或二进制解码,然后以高级编程语言重新创建源代码。 本文针对的是Windows操

该结构中最有趣的是InheritedFromUniqueProcessId字段。在这里,我们需要获取父进程的名称并将其与流行调试器的名称进行比较,以下是这种反调试检查的列表:

  1. std::wstring GetProcessNameById(DWORD pid) 
  2.     HANDLE hProcessSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0); 
  3.     if (hProcessSnap == INVALID_HANDLE_VALUE) 
  4.     { 
  5.         return 0; 
  6.     } 
  7.     PROCESSENTRY32 pe32; 
  8.     pe32.dwSize = sizeof(PROCESSENTRY32); 
  9.     std::wstring processName = L""; 
  10.     if (!Process32First(hProcessSnap, &pe32)) 
  11.     { 
  12.         CloseHandle(hProcessSnap); 
  13.         return processName; 
  14.     } 
  15.     do 
  16.     { 
  17.         if (pe32.th32ProcessID == pid) 
  18.         { 
  19.             processName = pe32.szExeFile; 
  20.             break; 
  21.         } 
  22.     } while (Process32Next(hProcessSnap, &pe32)); 
  23.      
  24.     CloseHandle(hProcessSnap); 
  25.     return processName; 
  26. status = NtQueryInformationProcess( 
  27.     GetCurrentProcess(), 
  28.     ProcessBasicInformation, 
  29.     &processBasicInformation, 
  30.     sizeof(PROCESS_BASIC_INFORMATION), 
  31.     NULL); 
  32. std::wstring parentProcessName = GetProcessNameById((DWORD)processBasicInformation.InheritedFromUniqueProcessId); 
  33. if (L"devenv.exe" == parentProcessName) 
  34.     std::cout << "Stop debugging program!" << std::endl; 
  35.     exit(-1); 

如何避开NtQueryInformationProcess检查

避开是非常简单的, NtQueryInformationProcess函数返回的值应该更改为那些不指示调试器存在的值:

1.将ProcessDebugObjectHandle设置为0

2.将ProcessDebugFlags设置为1

3.对于ProcessBasicInformation,将InheritedFromUniqueProcessId值更改为另一个进程ID,例如, Explorer.exe的

断点

断点,调试器的功能之一,可以让程序中断在需要的地方,从而方便其分析。两种类型的断点:

1.软件断点

2.硬件断点

在没有断点的情况下很难进行逆向工程,所以目前流行的反逆向工程策略都是基于检测断点,然后提供一系列相应的反调试方法。

软件断点

(编辑:西安站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读