继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

怎样阻止GDB依附应用问题的解决方式!!!(开发者须知)

X_X达达兔
关注TA
已关注
手记 8
粉丝 3
获赞 8

GDB是大多数hackers的首选,阻止GDB依附到应用的常规办法是:


1.  #import <sys/ptrace.h>  3.  int main(int argc, charchar *argv[])  
4.  {  
5.  #ifndef DEBUG  6.  ptrace(PT_DENY_ATTACH,0,0,0);  
7.  #endif  8.  @autoreleasepool {  
9.  return UIApplicationMain(argc, argv, nil, NSStringFromClass([WQMainPageAppDelegate class]));  
10.  }  
11.  }


但遗憾的是,iPhone真实的运行环境是没有sys/ptrace.h抛出的。虽然 ptrace 方法没有被抛出, 但是不用担心,我们可以通过dlopen拿到它。

dlopen: 当path 参数为0是,他会自动查找 $LD_LIBRARY_PATH,$DYLD_LIBRARY_PATH, $DYLD_FALLBACK_LIBRARY_PATH 和 当前工作目录中的动态链接库.

1.  #import <dlfcn.h>  2.  #import <sys/types.h>  4.  typedef int (*ptrace_ptr_t)(int _request, pid_t _pid, caddr_t _addr, int _data);  
5.  #if !defined(PT_DENY_ATTACH)  6.  #define PT_DENY_ATTACH 31  7.  #endif  // !defined(PT_DENY_ATTACH)  9.  void disable_gdb() {  
10.  void* handle = dlopen(0, RTLD_GLOBAL | RTLD_NOW);  
11.  ptrace_ptr_t ptrace_ptr = dlsym(handle, "ptrace");  
12.  ptrace_ptr(PT_DENY_ATTACH, 0, 0, 0);  
13.  dlclose(handle);  
14.  }  

16.  int main(int argc, charchar *argv[])  
17.  {  
18.  #ifndef DEBUG  19.  disable_gdb();  
20.  #endif  21.  @autoreleasepool {  
22.  return UIApplicationMain(argc, argv, nil, NSStringFromClass([WQMainPageAppDelegate class]));  
23.  }  
24.  }


--------“不积小流,无以成江海;不积跬步,无以至千里。 ”--------

谢谢iOS开发小伙伴们的点赞和支持 ! 万分感谢呢 ~.~

email GitHub  <感受下代码>

打开App,阅读手记
1人推荐
发表评论
随时随地看视频慕课网APP