溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Android Studio3.6如何調(diào)試smali

發(fā)布時間:2021-06-16 15:04:22 來源:億速云 閱讀:214 作者:小新 欄目:移動開發(fā)

這篇文章主要介紹Android Studio3.6如何調(diào)試smali,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!

 簡介

Smali是用于Dalvik(Android虛擬機(jī))的反匯編程序?qū)崿F(xiàn),匯編工具(將Smali代碼匯編為dex文件)為smali.jar,與之對應(yīng)的baksmali.jar則是反匯編程序(下載地址),官方所說的基于Jasmin/dedexer語法,實(shí)際根不知道是什么鬼……

Smali支持注解、調(diào)試信息、行數(shù)信息等基本Java的基本特性,可以說是很接近Java編譯在JVM上的中間語言了,一般用來做Android程序的逆向工程,還可以。。搞搞小名堂

個人認(rèn)為Smali只是用于做反匯編的一種語言實(shí)現(xiàn),如果可以,自己也能定義一套這樣的語言,實(shí)現(xiàn)反匯編的效果

好了,下面看下正文。

       以前在Android Studio中調(diào)試 smali 還是非常麻煩的時候,配置不好就是

Error running Smali: Unable to open debugger port (localhost:8700): java.io.IOException "handshake failed - connection prematurally closed

       目前最新版的 Android Studio 利用附加功能調(diào)試 smali 非常方便 ,操作步驟如下:

文中會用到工具及下載地址:

        ①、apktool.jar(目前最新版 v2.4.1),用于反編譯smali,

下載地址:    https://ibotpeaches.github.io/Apktool/ 

        ②、Android Studio (目前最新版本 3.6)用于Android開發(fā)調(diào)試IDE,

下載地址: https://developer.android.google.cn/studio/

        ③、smalidea-0.05.zip (目前最新版 0.05),AS 插件,用來給smali下斷點(diǎn),單步調(diào)試,

下載地址      https://bitbucket.org/JesusFreke/smali/downloads/

1.  先配置好Android Studio開發(fā)環(huán)境,這步就略去2. Android Studio中安裝 smalidea 插件,先從官網(wǎng)下載 smalidea zip包,然后在 Android 中依次選擇:

    File   -->  Setting   將會彈出設(shè)置對話框

Android Studio3.6如何調(diào)試smali

然后在設(shè)置對話框依次選擇:  Plugins   -->  <設(shè)置圖標(biāo)>  --> Install Plugin from Disk...

Android Studio3.6如何調(diào)試smali

在彈出選擇對話框中,找到下載好的 smalidea 壓縮包,選擇ok即可

Android Studio3.6如何調(diào)試smali

至此,插件安裝就完成了,關(guān)閉 Android Studio

3. 用 apktool 反編譯 apk 

    使用命令 : java.exe -jar  apktool.jar d -f  <xxxx.apk>  -o <xxxx目錄>

    也可以直接使用 ApkTool 集成環(huán)境(如果反編譯失敗可以替換其中的 apktool.jar 至最新版):

Android Studio3.6如何調(diào)試smali

在 反編譯出來的 AndroidManifest.xml 的 application 節(jié)點(diǎn)添加 android:debuggable="true"

然后在 主 Activity 中加入  invoke-static {},Landroid/os/Debug;->waitForDebugger()V

Android Studio3.6如何調(diào)試smali

重建且簽名 apk 

Android Studio3.6如何調(diào)試smali

安裝 重建后的 apk 到手機(jī) 

(這步如果重新打包失敗,可以安裝原始包,把手機(jī) root 配置/default.prop 的 ro.debuggable=1 開啟全局調(diào)試。

然后用命令啟動 Activiry : adb shell am start -D -n package屬性的值/android:name屬性的值  )

4. 將 反編譯工程導(dǎo)入到 Android Studio

 Android Studio3.6如何調(diào)試smali

默認(rèn)選擇 Create project from existing sources ,一路 next ,最后點(diǎn)擊 Finish 即可

用 Project 視圖,在項目目錄右鍵  --> Mark Directory as ... --> Sources root

Android Studio3.6如何調(diào)試smali

5. 展開 smali 目錄選擇剛才添加 waitForDebugger 代碼的 smali 文件下一行下斷點(diǎn)

Android Studio3.6如何調(diào)試smali

6. 運(yùn)行手機(jī)上安裝的apk(apk會假死停在 waitForDebugger 代碼處,等待調(diào)試器)。

7.在Android Studio選擇附加

Android Studio3.6如何調(diào)試smali

此時,已經(jīng) Attach 到進(jìn)程中,可以快樂的調(diào)試了

Android Studio3.6如何調(diào)試smali

以上是“Android Studio3.6如何調(diào)試smali”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI