Detecting debugger on Mac OS X

后端 未结 3 1960
隐瞒了意图╮
隐瞒了意图╮ 2021-02-10 15:43

I am trying to detect whether my process is being run in a debugger or not and, while in Windows there are many solutions and in Linux I use:

ptrace(PTRACE_ME,0         


        
3条回答
  •  醉话见心
    2021-02-10 16:19

    You can just call the function AmIBeingDebugged() from Apple Technical Q&A QA1361, which is reproduced here because Apple sometimes breaks documentation links and makes old documentation hard to find:

    #include 
    #include 
    #include 
    #include 
    #include 
    
    static bool AmIBeingDebugged(void)
        // Returns true if the current process is being debugged (either 
        // running under the debugger or has a debugger attached post facto).
    {
        int                 junk;
        int                 mib[4];
        struct kinfo_proc   info;
        size_t              size;
    
        // Initialize the flags so that, if sysctl fails for some bizarre 
        // reason, we get a predictable result.
    
        info.kp_proc.p_flag = 0;
    
        // Initialize mib, which tells sysctl the info we want, in this case
        // we're looking for information about a specific process ID.
    
        mib[0] = CTL_KERN;
        mib[1] = KERN_PROC;
        mib[2] = KERN_PROC_PID;
        mib[3] = getpid();
    
        // Call sysctl.
    
        size = sizeof(info);
        junk = sysctl(mib, sizeof(mib) / sizeof(*mib), &info, &size, NULL, 0);
        assert(junk == 0);
    
        // We're being debugged if the P_TRACED flag is set.
    
        return ( (info.kp_proc.p_flag & P_TRACED) != 0 );
    }
    

提交回复
热议问题