type
status
date
slug
summary
tags
category
icon
password
如果有些app需要输入密码和用户名之类的,用IDA静态调试,看不到,只能通过IDA动态调试APP。
动态调试步骤:
网上教程一大堆,不在赘述
实例1:ctf_100:
如果不达到要爬的楼层,是看不到FLAG的。
data:image/s3,"s3://crabby-images/919c9/919c9f80ab882e0504cba92daf0c133b303e9f39" alt="notion image"
反编译后,分析了一下,发现不用动态调试也可以,所以就直接在java层修改一下就可以了:
data:image/s3,"s3://crabby-images/c0d1f/c0d1f4b0efcf29e4da6fc3c456bc59f2ddca4f7a" alt="notion image"
只要去到
if-get
这一行的判断就可以了:data:image/s3,"s3://crabby-images/f4fda/f4fda7276d9345f7e9cc17a36caf633c2dfe4122" alt="notion image"
效果:只要爬一层楼,点击看FLAG就可以看到FLAG了:
data:image/s3,"s3://crabby-images/0f813/0f8131587d9f63df2a9c1d2ddc22f9e8f4119d5b" alt="notion image"
案例二:crackme1:
这次需要IDA动态调试才可以看到正确的输入密码:
data:image/s3,"s3://crabby-images/b148d/b148df6180e146e3c0f4ca5aea978283dfcc27e7" alt="notion image"
IDA调试步骤:
IDA先静态分析一下:
data:image/s3,"s3://crabby-images/ba955/ba9558d5c348aa6c35cc70f8bb3ec4fe087e5a85" alt="notion image"
分析bc为关键解密函数,
wolf_de
为解密函数,传入的应该是解密的密钥:data:image/s3,"s3://crabby-images/bd340/bd3405893440e597e82d1b184cd955fa284b64dc" alt="notion image"
data:image/s3,"s3://crabby-images/9955a/9955acbc18a061e910cfbc96a2576f1947f75a58" alt="notion image"
data:image/s3,"s3://crabby-images/08b47/08b47a69857b56bc86a6fefcf65574c9dbf6f734" alt="notion image"
data:image/s3,"s3://crabby-images/32984/3298492b8788712274b0209ba7aec19d18011800" alt="notion image"
data:image/s3,"s3://crabby-images/f8080/f8080f715617122d9072b7c51eec605ad131f542" alt="notion image"
data:image/s3,"s3://crabby-images/ca128/ca128ae6266a7373d0834a887936c41ea9020001" alt="notion image"
data:image/s3,"s3://crabby-images/711ac/711ac3201f182871f3c3b859d9355c01753b66d9" alt="notion image"
data:image/s3,"s3://crabby-images/ae862/ae86231127e16a339f2d0f1e43e78a058c8f16ad" alt="notion image"
data:image/s3,"s3://crabby-images/9b09d/9b09d81b9b6e413e35d7093b9e940f34e28f48f7" alt="notion image"
其实也可以在hex view中显示R6寄存器,就可以显示出密钥了
data:image/s3,"s3://crabby-images/307af/307afd830b21d99a03ec20a17f5cdc5e80021d9a" alt="notion image"
密码就是:
hello5.1
data:image/s3,"s3://crabby-images/24986/249860a2a7fd8a670be15d70570448cf084a150b" alt="notion image"
案例3:自毁程序密码:
data:image/s3,"s3://crabby-images/0ba8b/0ba8bb661953e5e67dd5ae35ac97f88a2df5cd60" alt="notion image"
IDA静态分析:
关键方法是
Java_com_yaotong_crackme_MainActivity_securityCheck
这个函数是静态注册函数,没有在jni_onload中进行静态注册:data:image/s3,"s3://crabby-images/cb6f3/cb6f34f278bef7d1778d7d7dc55295fdc17cf012" alt="notion image"
Java_com_yaotong_crackme_MainActivity_securityCheck
中的字符串并不是密钥:data:image/s3,"s3://crabby-images/b1631/b16318ffcb50ccd259fdf6175df3e00d612bfd82" alt="notion image"
IDA动态调试:
data:image/s3,"s3://crabby-images/7ba2b/7ba2bbdbc8b0de6fe23312a4eca1a02d0fd40836" alt="notion image"
小技巧:
在IDA中按ctrl+s找到segment窗口,找到载入so文件中的库的起始地址,用另一个IDA打开so文件,找到对应函数的偏移地址,绝对地址=基址+偏移地址(静态分析中的函数地址),绝对地址就是IDA动态分析中的函数的地址。
data:image/s3,"s3://crabby-images/c406b/c406bc7136a99f439478c73cefbf7499dec2c30f" alt="notion image"
运行到这里就可以看到密钥了:
data:image/s3,"s3://crabby-images/4edac/4edac551b799f3c5ee481707f2f5b8bfce7d3c61" alt="notion image"
data:image/s3,"s3://crabby-images/be406/be40600961d7d63550a7d4ada9615d11211c6fae" alt="notion image"
密钥是:
aiyou,bucuoo
案例4:find_tracer:
这个应用检测程序是否在被调试:
data:image/s3,"s3://crabby-images/e60ca/e60ca96f3f5020cdb8cad6dd75a8ae57ae4fee73" alt="notion image"
反调试检测的函数:
data:image/s3,"s3://crabby-images/21c49/21c49a89caffaca211b3fc94c3b8bd8bfa85665e" alt="notion image"
- 作者:lion
- 链接:https://blog-flame-tau.vercel.app/article/%E5%AE%89%E5%8D%93%E5%8A%A8%E6%80%81%E8%B0%83%E8%AF%95so%E6%96%87%E4%BB%B6
- 声明:本文采用 CC BY-NC-SA 4.0 许可协议,转载请注明出处。