1、結構體的創建及導入,結構體指針等。
以JniNativeInterface, DexHeader為例。
解析Dex的函數如下:
data:image/s3,"s3://crabby-images/5e685/5e6859a84b604bc6338007e5d48ff139146c7770" alt="\"
F5後如下:
data:image/s3,"s3://crabby-images/bf26d/bf26d5ddcc9b27e1d1c8803524598804633253d3" alt="\"
File->load file->parser c header file,導入Dex.h
上圖中a1,右鍵轉成結構體,選擇dexheader,效果如下:
data:image/s3,"s3://crabby-images/96266/96266b4f8307b4f4a8e09648866fcf27e10d52d3" alt="\"
2、函數指針時的參數個數調整,不定參數等。
以__android_log_print為例,選中該函數。
data:image/s3,"s3://crabby-images/67de6/67de6c7dec12e5f2249620146373c326b41fa722" alt="\"
Edit->operand type-> set operand type,修改參數如下:
int (__cdecl *)(int, char *, char *, char *, int *, int *),F5刷新後,效果如下:
data:image/s3,"s3://crabby-images/b5eb9/b5eb9a038810903346d5430937737b1f52faf9b4" alt="\"
3、thumb/arm模式的轉換
快捷鍵ALT +G,其中0x01是THUMB,0x00是ARM模式。一般4個字節ARM模式,兩個字節為THUMB模式,如:
data:image/s3,"s3://crabby-images/02db6/02db6805bd6d286a1c4c8212748c4342dd0f5e98" alt="\"
4、函數被誤認為chunk,導致調用者函數多個入口。
以Java_by_Ericky_crackme01_JNI_EatRice為例,可以看到有兩個入口。
data:image/s3,"s3://crabby-images/8f1cd/8f1cda6fa5a4c68bf4093f5663f442e138f82e3d" alt="\"
來到第一個入口的結束位置為BX跳轉指令, 應該讓他跳轉到第二個入口出,才正確。
data:image/s3,"s3://crabby-images/908bf/908bf48dfe9f31ec2dc36d6760d1c2c55aba1721" alt="\"
所有首先要remove function tail,
選中,結尾處,然後edit->functions->remove function tail,效果:
data:image/s3,"s3://crabby-images/a2067/a20672636b83f2a08dc1008621d0f8fa2d6b3eaa" alt="\"
然後再將跳轉指令BL,修改為Call,edit->others->force bl call,效果
data:image/s3,"s3://crabby-images/3fa8a/3fa8ae3904c5e476a2be3fb27462d50bac7d20af" alt="\"
5、C++RTTI,類名識別。
來的 JNI_OnLoad處
data:image/s3,"s3://crabby-images/2d503/2d503169530f4d8fa5483332d19d26dff0dba3ee" alt="\"
sub_A558為構造函數。
data:image/s3,"s3://crabby-images/d029e/d029ea2f6e3d2bbbaccfecbfa4322b560404470c" alt="\"
可以得在該函數名為9ArtLoader,
data:image/s3,"s3://crabby-images/0d4e8/0d4e84e132dbfaecf8a5e5803184d720a17684c2" alt="\"
6、創建函數,設定函數結尾地址。
F5,效果如下:
data:image/s3,"s3://crabby-images/752a4/752a40956b8aa0f73d2ecc539de32ecfec859a2b" alt="\"
解決辦法,按P,再F5。如果P沒有效果,則可以選中後再按P。
7、Elf的修復,內存dump該so及其以來文件,然後修改dump出來的基址,File-->LoadFile-->binary file。
dump命令為:
dd if=/proc/1935/mem of=/sdcard/alimsc4 skip=1578049536 ibs=1 count=3993600
8、數據復制、patch。
選中數據,然後edit->export data,即可
data:image/s3,"s3://crabby-images/ce629/ce6291685663850cbe5e7abbeece85f3484c5fe2" alt="\"
9、腳本,idc,IDAPython
http://magiclantern.wikia.com/wiki/IDAPython/intro
http://drops.wooyun.org/tips/11849
http://drops.wooyun.org/tips/12060
10、lsof查看被刪除的文件,cat從內存中得到被刪除的文件
root@android:/ # lsof |busybox grep com.sxiaoao.car3d3
system_se 523 system 298 /data/app/com.sxiaoao.car3d3-2.apk
com.sxiao 10370 u0_a65 44 /data/data/com.sxiaoao.car3d3/files/app_sdk103700_.jar (deleted)
com.sxiao 10370 u0_a65 48 /data/app/com.sxiaoao.car3d3-2.apk
com.sxiao 10370 u0_a65 49 /data/app/com.sxiaoao.car3d3-2.apk
10370是進程號 44是打開文件的fd 文件fd映射在/prop/pid/fd裡面
用cat命令把文件拷貝出來
1|root@android:/ # cat /proc/10370/fd/44 > /data/local/tmp/test.jar
11、arm指令模擬器
12、為什麼不能F5, 不能全信F5