如果有些app需要输入密码和用户名之类的,用IDA静态调试,看不到,只能通过IDA动态调试APP。
动态调试步骤:
网上教程一大堆,不在赘述
实例1:ctf_100:
如果不达到要爬的楼层,是看不到FLAG的。
data:image/s3,"s3://crabby-images/51a88/51a8843f7fc3b3be8fec7c088bdaf09d2d6912b5" alt="notion image"
反编译后,分析了一下,发现不用动态调试也可以,所以就直接在java层修改一下就可以了:
data:image/s3,"s3://crabby-images/5b161/5b1615c305a6d2f5e5a943ffa4b05b0d5ca4c06c" alt="notion image"
只要去到
if-get
这一行的判断就可以了:data:image/s3,"s3://crabby-images/d6575/d6575c55c6a53a69fd02b10a1833db7ad8ac3f2c" alt="notion image"
效果:只要爬一层楼,点击看FLAG就可以看到FLAG了:
data:image/s3,"s3://crabby-images/619e8/619e86ff640a6d95f82e5fd91cb44942fbddb5d1" alt="notion image"
案例二:crackme1:
这次需要IDA动态调试才可以看到正确的输入密码:
data:image/s3,"s3://crabby-images/f521e/f521ea52f01f064f824146aa94e401f96d6e5e2c" alt="notion image"
IDA调试步骤:
IDA先静态分析一下:
data:image/s3,"s3://crabby-images/b777a/b777ad7897eb960f16a873de178bd30fa6ac26d0" alt="notion image"
分析bc为关键解密函数,
wolf_de
为解密函数,传入的应该是解密的密钥:data:image/s3,"s3://crabby-images/5df46/5df46c365f4528aefe39ae0c0c672ef0361a1727" alt="notion image"
data:image/s3,"s3://crabby-images/15f2d/15f2d66df9dfd4da809da38af4993cabaf7a0442" alt="notion image"
data:image/s3,"s3://crabby-images/7ada5/7ada5afe47ed3fb5a1b17701ffb5b0559538c9ec" alt="notion image"
data:image/s3,"s3://crabby-images/49533/495339ea50528225b189dec991313ea02598dbae" alt="notion image"
data:image/s3,"s3://crabby-images/42f9b/42f9b3c4b86885066bd1d985dcc7ceb56af0b1a1" alt="notion image"
data:image/s3,"s3://crabby-images/30e14/30e142917ff065744b5a11364c0fac61c6884ec6" alt="notion image"
data:image/s3,"s3://crabby-images/24bf4/24bf493147e037196be1dbc8f14fa1c7ab681b0f" alt="notion image"
data:image/s3,"s3://crabby-images/ccda0/ccda0540488ce9ba2693b683b5022a25096292bc" alt="notion image"
data:image/s3,"s3://crabby-images/db280/db280f1c4a433c8ede69ac9d68841b37d7a3ece4" alt="notion image"
其实也可以在hex view中显示R6寄存器,就可以显示出密钥了
data:image/s3,"s3://crabby-images/7fba1/7fba151cf0890d079cfe940e29a6a32004f56893" alt="notion image"
密码就是:
hello5.1
data:image/s3,"s3://crabby-images/fde98/fde98fcd7d00a01f00961c57828472743bcd3656" alt="notion image"
案例3:自毁程序密码:
data:image/s3,"s3://crabby-images/b677e/b677e59b7713869ebf064fe62631c0d8554a974b" alt="notion image"
IDA静态分析:
关键方法是
Java_com_yaotong_crackme_MainActivity_securityCheck
这个函数是静态注册函数,没有在jni_onload中进行静态注册:data:image/s3,"s3://crabby-images/1ba55/1ba55beeb31bf80f25a05e9e7106d095a5fbde03" alt="notion image"
Java_com_yaotong_crackme_MainActivity_securityCheck
中的字符串并不是密钥:data:image/s3,"s3://crabby-images/0697b/0697bf123e0d684a521493a4cdb12c783a367c42" alt="notion image"
IDA动态调试:
data:image/s3,"s3://crabby-images/7b06e/7b06ed14a6e47b7eb2d499f0c3e382c6a3808d7f" alt="notion image"
小技巧:
在IDA中按ctrl+s找到segment窗口,找到载入so文件中的库的起始地址,用另一个IDA打开so文件,找到对应函数的偏移地址,绝对地址=基址+偏移地址(静态分析中的函数地址),绝对地址就是IDA动态分析中的函数的地址。
data:image/s3,"s3://crabby-images/ffee2/ffee2f29b1388341ce3ac21f031ff64f69c00d71" alt="notion image"
运行到这里就可以看到密钥了:
data:image/s3,"s3://crabby-images/c15f2/c15f2a16f2ab12cee5bc54133fa4f9f0146251a8" alt="notion image"
data:image/s3,"s3://crabby-images/2791b/2791b34e8f5ef1362a50d41ded47a0d490ca74b4" alt="notion image"
密钥是:
aiyou,bucuoo
案例4:find_tracer:
这个应用检测程序是否在被调试:
data:image/s3,"s3://crabby-images/170da/170da34286d31660246e7cfc375d8c0335a4ccee" alt="notion image"
反调试检测的函数:
data:image/s3,"s3://crabby-images/18770/18770522dd61257902abece8604c6fd5e86eeed2" alt="notion image"