zoukankan      html  css  js  c++  java
  • IDA远程调试so库JNI_Onload函数

    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中

  • 相关阅读:
    flutter sdk版本升级或者降级到指定版本
    flutter upgrage到1.17版本 android打包报错 Could not determine the dependencies of task ':app:lintVitalRelease'.
    小程序 自定义alert弹窗 带动画
    小程序 自定义cell 自定义group
    小程序 自定义弹窗禁止底部内容滚动 textarea内容上移
    css fixed 强制居中
    小程序 正则表达式
    小程序 自定义导航栏
    小程序 swiper自定义dot
    java 中锁的分类
  • 原文地址:https://www.cnblogs.com/shaoge/p/5425214.html
Copyright © 2011-2022 走看看