Android - NDK 共享库,使用 nm / objdump 提取相关的 JNI 钩子
Android - NDK Shared libraries extracting relevant JNI hooks with nm / objdump
我正在尝试从包含 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
由于 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");
确保您的库放置在 LD_LIBRARY_PATH
、/lib
目录中 Android 上,检查 mmap ( /proc/pid/maps
) 以查看它是否加载成功。
相关文章:
- 从包含m行的文件中提取n行,必要时(惰性地)重复该文件
- 如何从 std::atomic 中提取指针 T<T>?
- 为什么istream不支持右值提取
- 如何设置一个范围来提取我想要获得的信息
- 视觉工作室项目.提取源文件夹名称
- C++17 - 使用自定义分配器的节点提取/重新插入 - 适用于 clang++/libc++,但不适用于 libstd
- 从字符串中提取整数并形成一个数组
- C ++中的StringStream有助于使用向量从字符串中提取逗号分隔的整数,而不是空格分隔的整数,为什么?
- asn1c 不会从 asn.1 模块中提取八位字节字符串的默认值
- 从 std::vector<无符号字符>切片中提取 int?
- 在C++中使用重载提取运算符时出现问题
- 在 Qt(C++) 中使用 QProcess 解压缩 - 提取目录问题
- C++(.cpp文件和.h文件)拆分代码并添加一个函数,提取 - 这很容易吗?
- 无法从 std::string 中提取C++ Unicode 符号
- 如何从也包含C++字母的文本文件中提取某些数字?
- 如何从适合一定范围的数字中提取数字?
- C++从通用引用中提取实际类型
- 从运行服务的应用程序代码中提取窗口句柄
- 如何在字符串中找到字符,然后在C++中提取其余的字符串
- Android - NDK 共享库,使用 nm / objdump 提取相关的 JNI 钩子