【问题标题】:Android - NDK Shared libraries extracting relevant JNI hooks with nm / objdumpAndroid - NDK 共享库使用 nm / objdump 提取相关 JNI 钩子
【发布时间】:2012-06-20 21:59:38
【问题描述】:

我正在尝试从包含 JNI 胶水代码的共享库中提取相关符号,但 nm 似乎没有足够的帮助。方法签名不存在,所以我不知道要传递哪些参数。

有什么想法吗?

bash-3.2# ./arm-linux-androideabi-nm -D ~/Desktop/backup/whiteBox/libamplayerjni.so | grep Java
00030d6c T Java_com_farcore_playerservice_AmPlayer_GL2XScale
00030da8 T Java_com_farcore_playerservice_AmPlayer_close
00030d74 T Java_com_farcore_playerservice_AmPlayer_disable2X2XYScale
...

obdump 也无济于事

bash-3.2# ./arm-linux-androideabi-objdump -TC ~/Desktop/backup/whiteBox/libamplayerjni.so | grep Java
00030c00 g    DF .text  00000008 Java_com_farcore_playerservice_AmPlayer_getDivxInfo
00030c08 g    DF .text  00000008 Java_com_farcore_playerservice_AmPlayer_setIVolume
00030c10 g    DF .text  00000008 Java_com_farcore_playerservice_AmPlayer_mute
00030c18 g    DF .text  00000008 Java_com_farcore_playerservice_AmPlayer_unmute
00030c20 g    DF .text  00000008 Java_com_farcore_playerservice_AmPlayer_setVideoBlackOut

【问题讨论】:

    标签: android c++ c linux android-ndk


    【解决方案1】:

    由于 JNI 使用 C 调用约定 (cdecl),因此函数签名中没有参数信息。你需要分析对应的java(dalvik)代码来找出参数类型。

    这是我的 jni 库:

    00001408 g    DF .text  0000000a Java_info_kghost_android_openvpn_FileDescriptorHolder_close
    00001a14 g    DF .text  00000198 Java_info_kghost_android_openvpn_ManagementSocket_read__ILjava_nio_ByteBuffer_2II
    00001414 g    DF .text  0000000c Java_info_kghost_android_openvpn_ManagementSocket_shutdown
    000017c4 g    DF .text  00000250 Java_info_kghost_android_openvpn_ManagementSocket_read__ILjava_nio_ByteBuffer_2IILinfo_kghost_android_openvpn_FileDescriptorHolder_2
    0000142c g    DF .text  00000200 Java_info_kghost_android_openvpn_ManagementSocket_write__ILjava_nio_ByteBuffer_2IILinfo_kghost_android_openvpn_FileDescriptorHolder_2
    00001420 g    DF .text  0000000a Java_info_kghost_android_openvpn_ManagementSocket_close
    0000162c g    DF .text  00000198 Java_info_kghost_android_openvpn_ManagementSocket_write__ILjava_nio_ByteBuffer_2II
    00001bd4 g    DF .text  000000d4 Java_info_kghost_android_openvpn_ManagementSocket_open
    

    如果没有重载方法,签名将不包含参数信息;如果方法被重载,签名将在函数名中包含参数信息。

    并且你需要在使用原生方法之前显式加载 jni 库:

    System.loadLibrary("your-library-name");
    

    确保你的库放在Android上的LD_LIBRARY_PATH/lib目录下,检查mmap(/proc/pid/maps)看是否加载成功。

    【讨论】:

    • 这听起来有道理,但是VM经常会抱怨找不到与签名Lcom匹配的函数...(IIIIII)V。
    • 您必须确保库已加载
    • 库已加载...必须有一种方法可以使用面向公众的 JNI 挂钩从共享库中获取函数签名。
    猜你喜欢
    • 1970-01-01
    • 2014-03-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-02-20
    • 2014-11-10
    • 2015-03-27
    • 2013-07-15
    相关资源
    最近更新 更多