反调试:利用Java层API来判断Android程序是否是处于被调试下。
1.直接调用系统的android.os.Debug.isDebuggerConnected()方法
我们进行动态调试的时候,其中有一个步骤是进行jdb连接操作:jdb -connect com.sun.jdi.SocketAttach:hostname=127.0.0.1,port=8700,当接连成功之后,android.os.Debug.isDebuggerConnected() 这个方法就会ture,那么我们可以利用这个api来进行判断当前应用是否处于调试状态来进行反调试操作。
![](https://images2015.cnblogs.com/blog/1118630/201705/1118630-20170502141618820-193215537.png)
解决方案:
使用反编译工具方便程序,然后搜索isDebuggerConnected() 关键字, 然后Nop 掉改函数的调用
反调试:判断当前应用属性:ApplicationInfo.FLAG_DEBUGGABLE
调试者为了让自己的程序能够调试, 就会在反编译后AndroidMainfiest,xml 中添加:android:debuggable="true", 然后进行调试。利用这一点我们用于反调试
![](https://images2015.cnblogs.com/blog/1118630/201705/1118630-20170502141620492-1746498300.png)
添加这个属性之后,我们可以用dumpsys package [packagename]命令查看debug状态
![](https://images2015.cnblogs.com/blog/1118630/201705/1118630-20170502141621789-232693673.png)
实现反调试的代码如下:
![](https://images2015.cnblogs.com/blog/1118630/201705/1118630-20170502141622961-818001313.png)
解决方案:
使用反编译工具方便程序,然后搜索getApplicationInfo等关键字, 然后Nop 掉改函数的调用