Android逆向之動態(tài)調(diào)試Smali代碼

1. 為什么要學會動態(tài)調(diào)試Smali代碼?

為了減輕我們逆向分析的負擔枝笨!
Smali文件中代碼量是十分龐大的层宫,而且Smali語法也并不是那么容易就會明白,逆向分析APK嘴秸,試圖找到它的漏洞毁欣,面對大篇幅的Smali文件代碼,還有現(xiàn)如今基本上每一款商業(yè)級的App為了安全都會采用混淆和加殼策略岳掐,就算使用ApkTool等工具將APK反編譯成Smali文件凭疮,生成的Smali代碼還是一堆諸如:a,b串述,c执解,d.....等無用的類、函數(shù)纲酗、變量衰腌。可能完全找不到實現(xiàn)程序功能的“真正”代碼觅赊!因此采用動態(tài)調(diào)試的方法右蕊,以打斷點的方式來逐步調(diào)試Smali代碼是勢在必行的一個技能。動態(tài)調(diào)試也是逆向的基本技能吮螺!

2. 動態(tài)調(diào)試Smali代碼總結

參考鏈接(建議查看此教程饶囚,自己搭建環(huán)境進行Smali代碼的動態(tài)調(diào)試)

(1) 知識點兒

  • 遠程調(diào)試的前題是:確認調(diào)試APK的AndroidManifest.xml文件中,<application>標簽的android:debuggable屬性為true鸠补。
  • DDMS
    Dalvik Debug Monitor Serivce萝风,Dalvik調(diào)試監(jiān)控服務,為Android SDK提供的一款擁有監(jiān)控Dalvik虛擬機的調(diào)試軟件紫岩,啟動:打開Andorid SDK選擇Tools>Android>Android Device Monitor规惰。
  • adb forward命令
    用于創(chuàng)建一個端口映射,將本地端口(本地PC端口)泉蝌,映射到遠程端口(測試軟件使用的手機)
    例如這里用到的:adb forward tcp:8700 jdwp:5657
  • JDWP
    Java Debug Wire Protocol歇万,Java調(diào)試線程協(xié)議揩晴,定義了調(diào)試器(debugger)和被調(diào)試的 Java 虛擬機(target vm)之間的通信協(xié)議。

為什么使用JDWP協(xié)議堕花?
Dalvik虛擬機會啟動一個JDWP線程文狱,用于遠程調(diào)試。遠程調(diào)試器可以通過JDWP端口號缘挽,調(diào)試指定進程瞄崇。每個可調(diào)試的進程的PID就是其JDWP的端口號『韭可以使用adb jdwp命令查看所有可以調(diào)試的進程PID(需要使用ctrl + c退出)苏研。

  • 在.method字段,使用"Find Usage"功能腮郊,可以定位該方法的所有調(diào)用者摹蘑。
  • 在方法類型上,使用"Declaration"轧飞,可以定位方法的定義處衅鹿。

(2) 動態(tài)調(diào)試基本流程

a. 首先使用ApkTool工具反編譯APK文件,得到Smali文件过咬。
b. 然后使用AS打開反編譯APK生成的文件夾大渤。并將Smali文件,設置成Source Root 文件掸绞。
c. 然后創(chuàng)建遠程調(diào)試(調(diào)試的本地端口一般為8700)
d. 然后啟動應用:
adb shell am start -D -n 主活動路徑/主活動泵三,在Android Device Monitor查看端口號和程序的PID。
e. 然后綁定端口:adb forward tcp:8700 jdwp:5657
f. 如果調(diào)試過程中衔掸,修改了代碼烫幕。需要使用apktool重新打包,重新安裝敞映。之后重復6步驟较曼,開始調(diào)試。
g. 調(diào)試結束后振愿,建議使用adb forward --remove-all命令诗芜,清理端口綁定。

(3) 注意

  • 如果先查打開DDMS查看端口埃疫,再去設置進程debug,進程的pid會變孩哑,此時會出現(xiàn)錯誤提示:


    報錯1
  • 如果未開啟端口轉發(fā)栓霜,則會出現(xiàn)如下錯誤:


    報錯2
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市横蜒,隨后出現(xiàn)的幾起案子胳蛮,更是在濱河造成了極大的恐慌销凑,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,640評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件仅炊,死亡現(xiàn)場離奇詭異斗幼,居然都是意外死亡,警方通過查閱死者的電腦和手機抚垄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,254評論 3 395
  • 文/潘曉璐 我一進店門蜕窿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人呆馁,你說我怎么就攤上這事桐经。” “怎么了浙滤?”我有些...
    開封第一講書人閱讀 165,011評論 0 355
  • 文/不壞的土叔 我叫張陵阴挣,是天一觀的道長。 經(jīng)常有香客問我纺腊,道長畔咧,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,755評論 1 294
  • 正文 為了忘掉前任揖膜,我火速辦了婚禮誓沸,結果婚禮上,老公的妹妹穿的比我還像新娘次氨。我一直安慰自己蔽介,他們只是感情好,可當我...
    茶點故事閱讀 67,774評論 6 392
  • 文/花漫 我一把揭開白布煮寡。 她就那樣靜靜地躺著虹蓄,像睡著了一般。 火紅的嫁衣襯著肌膚如雪幸撕。 梳的紋絲不亂的頭發(fā)上薇组,一...
    開封第一講書人閱讀 51,610評論 1 305
  • 那天,我揣著相機與錄音坐儿,去河邊找鬼律胀。 笑死,一個胖子當著我的面吹牛貌矿,可吹牛的內(nèi)容都是我干的炭菌。 我是一名探鬼主播,決...
    沈念sama閱讀 40,352評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼逛漫,長吁一口氣:“原來是場噩夢啊……” “哼黑低!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,257評論 0 276
  • 序言:老撾萬榮一對情侶失蹤克握,失蹤者是張志新(化名)和其女友劉穎蕾管,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體菩暗,經(jīng)...
    沈念sama閱讀 45,717評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡掰曾,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,894評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了停团。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片旷坦。...
    茶點故事閱讀 40,021評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖客蹋,靈堂內(nèi)的尸體忽然破棺而出塞蹭,到底是詐尸還是另有隱情,我是刑警寧澤讶坯,帶...
    沈念sama閱讀 35,735評論 5 346
  • 正文 年R本政府宣布番电,位于F島的核電站,受9級特大地震影響辆琅,放射性物質發(fā)生泄漏漱办。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,354評論 3 330
  • 文/蒙蒙 一婉烟、第九天 我趴在偏房一處隱蔽的房頂上張望娩井。 院中可真熱鬧,春花似錦似袁、人聲如沸洞辣。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,936評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽扬霜。三九已至,卻和暖如春而涉,著一層夾襖步出監(jiān)牢的瞬間著瓶,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,054評論 1 270
  • 我被黑心中介騙來泰國打工啼县, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留材原,地道東北人。 一個月前我還...
    沈念sama閱讀 48,224評論 3 371
  • 正文 我出身青樓季眷,卻偏偏與公主長得像余蟹,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子子刮,可洞房花燭夜當晚...
    茶點故事閱讀 44,974評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 魚曰水木 一段回憶 一塵過往 湖心楓葉流轉隨風飛揚 一本詩集 一篇徜徉 手牽手英語角享受陽光 ...
    緣起緣落是哀愁閱讀 206評論 2 1
  • 天冷了威酒,入冬,有點飄雪花。 我在火車上看著窗外的景色兼搏。 車上人很多。許多人沒有座沙郭,擠在過道里佛呻。 我聽著耳機里的歌,...
    豆豉順順閱讀 194評論 1 1
  • 近日胃不舒服,不舒服的表征就是你時刻知道有個胃在那里~~所以我總結了下送挑,當身體零部件刷存在感绑莺、求關注時,就會比較痛...
    曹曉輝閱讀 741評論 0 0