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中

  • 相关阅读:
    mven系列问题
    log4j.properties配置说明
    java jar打包命令使用
    提高效率必须改掉的7种习惯
    JVM参数详解(官方)
    session过期的三种方法
    spring中的@PostConstruct注解的用法
    css中隐藏元素的几种方法,和与用户交互问题
    html中动态加载<script>到页面<head>中
    js中window.location中的各种用法
  • 原文地址:https://www.cnblogs.com/shaoge/p/5425214.html
Copyright © 2011-2022 走看看