码迷,mamicode.com
首页 > 其他好文 > 详细

IDA远程调试so库JNI_Onload函数

时间:2016-04-23 19:55:07      阅读:772      评论:0      收藏:0      [点我收藏+]

标签:

JNI_OnLoad函数大概功能就是在程序加载so的时候,会执行JNI_OnLoad函数,做一系列的准备工作。
很多时候,程序猿们会将一些重要信息放在此函数中,而不是通过某种事件来重复触发。包括说将反调试函数放置在此函数中。因此,调试手段发生了改变,上述调试方法基本上被淘汰。

 

1.静态分析,找到JNI_OnLoad函数的偏移

技术分享

2.执行android_server

技术分享

3.端口转发

技术分享

4. 以调试模式启动程序
adb shell am start -D -n com.example.mytestcm/.MainActivity
此时,手机界面会出现Waiting For Debugger页面

技术分享

技术分享

5.打开ddms或者Eclipse (必要,为了使用jdb命令),获取应用程序的端口号

技术分享

6.IDA附加

技术分享

技术分享

7.设置调试选项

技术分享

技术分享

8. F9运行程序

技术分享

在命令行中执行:jdb -connect com.sun.jdi.SocketAttach:hostname=127.0.0.1,port=8700其中port=8700是从ddms中看到的。

技术分享

此时程序会断下来

技术分享

9.下断点,首地址加偏移,跟上一篇远程调试的方法一样

技术分享

技术分享

下好断点之后,直接F9运行吧,就能断在JNI_OnLoad函数处~

技术分享

 

当这种调试手法出现之后,将特殊函数,或者反调试函数放在JNI_OnLoad中也不是那么的安全了。此时,程序猿们通过分析系统对SO文件的加载链接过程发现,JNI_OnLoad函数并不是最开始执行的。在JNI_OnLoad函数执行之前,还会执行init段和init_array中的一系列函数。

因此,现在的调试方法,都是将断点下在init_array中~
至于下断点的方法,可以类比于在JNI_OnLoad中下断点的方法,在init_array的函数中下断点。还有一种方法便是通过在linker模块中,通过对其中函数下断点,然后也能单步到init_array中

 

IDA远程调试so库JNI_Onload函数

标签:

原文地址:http://www.cnblogs.com/shaoge/p/5425214.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!