android中SO文件动态调试

0X00 前言

为了增加APK文件的破解难度,很多比较重要的功能都是通过native实现,与反编译不同的是,java的伪代码可以很清楚的得到程序的逻辑关系,但是so文件反编译得到的是汇编代码,使用ida这样的神器可以得到c的伪代码。使用ida实现so的动态调试,可以在关键地方下断点,对于一些变换,比如有的时候输入的内容与经过一些列的变换后的结果比较,这个时候我们不需要关心中间的变换过程,在动态调试的时候,在比较的地方下个断点,然后在内存中查看此时比较的常量。正好最近做了CTF的一个re。顺便熟悉下ida的动态调试步骤。

0x01 APK逻辑的简单分析

在apk的manifest文件里,我们得到apk的入口avtivity。包括包名和主类。

2

通过一步步分析,得知:用户输入 用户名和 密码, 其中用户名必须是 <string name=”username”>secl-007</string> ,而密码的判断逻辑是调用了native函数(Java_com_ssctf_seclreg_Seclo0o_getpl )去判断,这个时候用ida静态分析,打开apk加载的so文件,通过分析,我们发现对于输入的密码没有进行任何处理,只是判断输入密码的长度,如果长度是39,然后和一个常量做比较,是否正确。而这个常量在运行过程经过一些列的变化,因此我们不需要关心变化的过程。有两个方法:

  1. 输入任意长度为39的内容,然后dump整个程序的内存,这个时候在dump内容中寻找,(因为我们知道这个常量特定方式SSCTF{*****)
  2. 使用IDA动态调试,在比较的地方下断点,得到此时常量的内容。这篇文章我们使用第二种方法实现

3

0x02 IDA动态调试SO

关于IDA动态调试步骤,首先你的手机需要ROOT。

  1. 把ida目录下的android_server文件放到手机的目录,adb pull android_server /data/local/tmp
  2. 给与android_server 777 权限, chmod 777 android_server
  3. 端口的转发 adb forward tcp:23946 tcp:23946
  4. 打开ddms
  5. 运行android_server ./android_server
  6. 将要调试的apk文件以调试的方式运行 adb shell am start -D -n com.ssctf.seclreg/.Seclreg   包名/.类名
  7. 这个时候手机显示等到调试连接模式,打开ida,debugger-attach-remote android server 4
  8. 选择ok,并且F9运行,这个时候,jdb附加程序,jdb -connect com.sun.jdi.SocketAttach:hostname=127.0.0.1,port=8700
  9. 这样程序就可以动态调试了,我们根据SO基址和函数的偏址找到调试时候函数的地址,然后F2 下断点,

这个时候在APK输入,然后程序运行到我们设置断点的地方,

1

然后我们在数据窗口里查看数据,得到FLAG:)

原文地址: https://www.ijiza.cn/2016/03/03/android%E4%B8%ADso%E6%96%87%E4%BB%B6%E5%8A%A8%E6%80%81%E8%B0%83%E8%AF%95/
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 Android Studio 调试so文件,您需要进行以下配置: 1. 在 app 的 build.gradle 文件添加以下代码: ``` android { defaultConfig { ndk { // 设置需要调试的CPU架构 abiFilters 'armeabi-v7a', 'arm64-v8a', 'x86', 'x86_64' } } } ``` 2. 在项目的 build.gradle 文件添加以下代码: ``` android { externalNativeBuild { cmake { // 设置cmake的版本 version "3.10.2" // 设置需要编译的CMake文件路径 path "CMakeLists.txt" } } } ``` 3. 在 CMakeLists.txt 文件添加以下代码: ``` # 添加头文件搜索路径 include_directories(${CMAKE_SOURCE_DIR}/include) # 添加预编译库搜索路径 link_directories(${CMAKE_SOURCE_DIR}/libs/${ANDROID_ABI}) # 添加需要编译的C++文件 add_library( native-lib SHARED native-lib.cpp ) # 添加需要链接的预编译库 target_link_libraries( native-lib log ) ``` 4. 在 MainActivity.java 文件添加以下代码: ``` static { System.loadLibrary("native-lib"); } public native String stringFromJNI(); ``` 5. 在 native-lib.cpp 文件添加以下代码: ``` #include <jni.h> #include <string> extern "C" JNIEXPORT jstring JNICALL Java_com_example_myapplication_MainActivity_stringFromJNI( JNIEnv* env, jobject /* this */) { std::string hello = "Hello from C++"; return env->NewStringUTF(hello.c_str()); } ``` 6. 在 Android Studio 选择 Run > Edit Configurations,然后添加一个新的配置。 7. 在配置选择您的应用程序模块,并将“Launch Options”设置为“Nothing”。 8. 在“Debugger”选项卡,选择“Attach debugger to Android process”。 9. 在“Debugger”选项卡,将“Debugger type”设置为“Native”. 10. 现在您可以启动应用程序,并在应用程序调用 `stringFromJNI()` 方法,以便在 ndk 进行调试。 希望这些步骤能够帮助您在 Android Studio 成功调试so文件

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值