data:image/s3,"s3://crabby-images/710fb/710fb16b42eed188d667ff18a9f2af2343c8eb06" alt="Ollydbg debugger detected"
data:image/s3,"s3://crabby-images/726c4/726c42484ab7933b1272c44a42e9725d3e15f8b1" alt="ollydbg debugger detected ollydbg debugger detected"
It is set to 1 when the process is being debugged, otherwise it's set to 0. The PEB struct contains a byte field named BeingDebugged. We'll start querying the PEB using assembly. We could say it's the equivalent of the kernel mode data structure EPROCESS. It contains info about the process such as the base address, The PEB is used internally by the system.
data:image/s3,"s3://crabby-images/b8cef/b8cef2f89d0bbef0095e6ec3e617e31ea8d40757" alt="ollydbg debugger detected ollydbg debugger detected"
The Process Environment Block is a user mode data structure inside the process virtual address space. We'll simply use these differences to check the presence of a debugger. Most (if not all) anti-debug techniques rely on the fact that the system and the concerned app have aĭifferent behaviour when an app is being debugged than when it isn't. By the way, all of this is Windows specific. Techniques nor other adavanced protections. In this paper, we'll go over some basic anti-debug tricks.
data:image/s3,"s3://crabby-images/a69af/a69af69ebe316e6fc152e98f1ed665c9a1984e92" alt="ollydbg debugger detected ollydbg debugger detected"
Basic anti-debug tricks Posted by Preacher on June 6, 2013Ġ - Introduction 1 - Techniques related to the PEB 1.1 - asm way (inline asm) 1.2 - C Win32 way 2 - Timing based detection 3 - OllyDbg specific 3.1 - OllyDbg v1 3.2 - OllyDbg v2 4 - Custom ways 4.1 - OutputDebugString(): Again (Xp SP 3 only) 4.2 - Parent Process Id (PPID) check 4.3 - Terminate the debugger 5 - Resources Introduction
data:image/s3,"s3://crabby-images/710fb/710fb16b42eed188d667ff18a9f2af2343c8eb06" alt="Ollydbg debugger detected"