前言: 当一个进程被调试时,该进程中会有一个标记位来标记他是否被调试.可以通过systrl函数来查看当前进程的信息,通过是否有这个标记位即可检查当前调试的状态
1.反调试
data:image/s3,"s3://crabby-images/d9838/d98389924887d7b3254e7a3c9212e6ca952adbde" alt=""
data:image/s3,"s3://crabby-images/dedf5/dedf55281786341f7d500168b6ecbd1cda2014e6" alt=""
我们先来看看xcode连接调试的状态
data:image/s3,"s3://crabby-images/e5c4a/e5c4a330d53e8e2354e641d0e9d5170664b8683a" alt=""
现在我们断开Xcode 用控制台看
data:image/s3,"s3://crabby-images/9ad18/9ad18895ee768fff5c2559940de235abb19de068" alt=""
2.反反调试
反反调试的逻辑就是注入动态库因为systrl是系统函数 用fishhook hook能hook systrl
1)新建一个动态库插入到ipa中
data:image/s3,"s3://crabby-images/04932/04932cadee0bdad8f8d4860c857fcb3c12ff8715" alt=""
data:image/s3,"s3://crabby-images/815c8/815c8ad1ed4eb738f55f50179df2b5f90c216bf4" alt=""
需要注意的是 我门在fishhook里面需要保留系统其他sysctl的用法 只需要hook监听调试的逻辑
网友评论