龙马谷

 找回密码
 立即注册

QQ登录

只需一步,快速开始

龙马谷VIP会员办理客服QQ:82926983(如果临时会话没有收到回复,请先加QQ好友再发。)
1 [已完结] GG修改器新手入门与实战教程 31课 2 [已完结] GG修改器美化修改教程 6课 3 [已完结] GG修改器Lua脚本新手入门教程 12课
4 [已完结] 触动精灵脚本新手入门必学教程 22课 5 [已完结] 手游自动化脚本入门实战教程 9课 6 [已完结] C++射击游戏方框骨骼透视与自瞄教程 27课
7 [已完结] C++零基础UE4逆向开发FPS透视自瞄教程 29课 8 [已完结] C++零基础大漠模拟器手游自动化辅助教程 22课 9 [已完结] C++零基础开发DXF内存脚本辅助教程 32课
以下是天马阁VIP教程,本站与天马阁合作,赞助VIP可以获得天马阁对应VIP会员,名额有限! 点击进入天马阁论坛
1 [已完结] x64CE与x64dbg入门基础教程 7课 2 [已完结] x64汇编语言基础教程 16课 3 [已完结] x64辅助入门基础教程 9课
4 [已完结] C++x64内存辅助实战技术教程 149课 5 [已完结] C++x64内存检测与过检测技术教程 10课 6 [已完结] C+x64二叉树分析遍历与LUA自动登陆教程 19课
7 [已完结] C++BT功能原理与x64实战教程 29课 8 [已完结] C+FPS框透视与自瞄x64实现原理及防护思路
查看: 4504|回复: 0

OD/CE 过掉TMD壳附加检查

[复制链接]

15

主题

11

回帖

32

积分

编程入门

Rank: 1

龙马币
58

恢复OD进程附加原理


1、恢复DbgBreakPoint和DbgUiRemoteBreakin被HOOK代码

//由于我是使用ntdll SDK,可直接使用NTDLL中的API,如果你们不能使用,直接用GetProcAddress获取API

注意该处的修复,自己可以写个HOOK,放到LoadLibrary,每次加载DLL时候,就处理一次,防止某些DLL还有TMD壳,又会被恢复

ntdll->DbgBreakPoint 被TMD壳修改为retn -> 0xC3

DWORD lpflOldProtect;
LPVOID ulAddress = DbgBreakPoint;
VirtualProtect(ulAddress,1,PAGE_EXECUTE_READWRITE,&lpflOldProtect);

*(BYTE*)(ulAddress) = 0xCC;

ntdll->DbgUiRemoteBreakin 被TMD修改为 JMP LdrShutdownProcess

ulAddress = DbgUiRemoteBreakin

VirtualProtect(ulAddress,1,PAGE_EXECUTE_READWRITE,&lpProtect);
*(BYTE*)(ulAddress) =0x6A;
*(DWORD*)((BYTE*)ulAddress+1)= 0xFC686808;


2、修复允许CE的附加

第一步虽然修复了允许附加,但TMD壳本身还自带线程检查ANTI,所以我们要终止掉这些线程


  1. BOOL WINAPI _AhnHS_GetThreadModuleName(char* szModuleName,DWORD szThreadId,LPVOID & StartAddress,HANDLE & hThread) {
  2.         hThread  = OpenThread(THREAD_ALL_ACCESS, FALSE, szThreadId);
  3.         if (!hThread) return FALSE;
  4.         LONG status
  5.         = ZwQueryInformationThread(hThread, ThreadQuerySetWin32StartAddress, &StartAddress, sizeof(StartAddress), NULL);
  6.         if(status <0) {
  7.                 CloseHandle(hThread);
  8.                 SetLastError(RtlNtStatusToDosError(status));
  9.                 return FALSE;
  10.         }
  11.         return (GetMappedFileNameA(GetCurrentProcess(), StartAddress, szModuleName, MAX_PATH)>=0) ? TRUE : FALSE;
  12. }
  13. void WINAPI _AhnHS_PassThreadByTMD() {
  14.         HANDLE hThreadSnap , hThread;
  15.         THREADENTRY32 te32 = {0};
  16.         CONTEXT context= {0};
  17.         hThreadSnap = CreateToolhelp32Snapshot(TH32CS_SNAPTHREAD, 0);
  18.         if ( hThreadSnap == INVALID_HANDLE_VALUE )
  19.         return;
  20.         memset(&te32, 0, sizeof(THREADENTRY32));
  21.         te32.dwSize  = sizeof(THREADENTRY32);
  22.         BOOL dwRet = Thread32First(hThreadSnap, &te32);
  23.         DWORD dwCurrentProcessId = GetCurrentProcessId();
  24.         do {
  25.                 if (te32.th32OwnerProcessID != dwCurrentProcessId) continue;
  26.                 char szModuleFileName[MAX_PATH];
  27.                 LPVOID  StartAddress;
  28.                 if(!_AhnHS_GetThreadModuleName(szModuleFileName,te32.th32ThreadID,StartAddress,hThread)) continue;
  29.                 char* pszName
  30.                 = (strrchr(szModuleFileName,'\\')) ? strrchr(szModuleFileName,'\\')+1 : szModuleFileName;
  31.                 //AntiHookGetMainThreadId()=主线程ID,可自行修改
  32.                 if(lstrcmpiA(pszName,AntiHookGetModuleInfo()->AppName)==0 && AntiHookGetMainThreadId()!=te32.th32ThreadID) {
  33.                         //远程线程非代码块,为其它检查线程,终止
  34.                         HMODULE  lib = GetModuleHandleA(pszName);
  35.                         PIMAGE_NT_HEADERS
  36.                         nth =  PIMAGE_NT_HEADERS(PBYTE(lib) + PIMAGE_DOS_HEADER(lib)->e_lfanew);
  37.                         IMAGE_SECTION_HEADER
  38.                         *pSection =
  39.                         (IMAGE_SECTION_HEADER*)((DWORD)nth + sizeof(IMAGE_NT_HEADERS));
  40.                         if((DWORD)StartAddress>(pSection[0].VirtualAddress+(DWORD)lib) && (DWORD)StartAddress<pSection[1].VirtualAddress+(DWORD)lib) continue;
  41.                         TerminateThread(hThread,0);
  42.                 }
  43.                 CloseHandle(hThread);
  44.         }
  45.         while(Thread32Next(hThreadSnap, &te32));
  46.         CloseHandle(hThreadSnap);
  47. }
复制代码


OK,万事大吉,世界清静了
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

龙马谷| C/C++辅助教程| 安卓逆向安全| 论坛导航| 免责申明|Archiver|
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表龙马谷立场!
任何人不得以任何方式翻录、盗版或出售本站视频,一经发现我们将追究其相关责任!
我们一直在努力成为最好的编程论坛!
Copyright© 2018-2021 All Right Reserved.
在线客服
快速回复 返回顶部 返回列表