反編譯的常用工具與使用方法

歡迎Follow我的GitHub, 關(guān)注我的簡(jiǎn)書. 其余參考Android目錄.

Reverse Engineering

本文的合集已經(jīng)編著成書,高級(jí)Android開發(fā)強(qiáng)化實(shí)戰(zhàn),歡迎各位讀友的建議和指導(dǎo)。在京東即可購買:https://item.jd.com/12385680.html

Android

逆向工程(Reverse Engineering)解析apk, 驗(yàn)證特性, 替換資源. 在批量生成應(yīng)用時(shí), 通過服務(wù)器腳本修改apk, 節(jié)約人力和時(shí)間. 我來講述一下, 逆向工程的常用工具和方法.


1. apk

apk表示Application PacKage, 是zip文件, 修改后綴名.apk.zip, 解壓獲得apk信息.

解壓

應(yīng)用信息:
AndroidManifest.xml: 二進(jìn)制清單文件.
classes.dex: Dex格式編譯文件.
resources.arsc: 二進(jìn)制預(yù)編譯資源文件.
res: 不需編譯的資源文件, 一般都是系統(tǒng)的資源文件.
assets: AssetManager檢索應(yīng)用特性.
META-INF: Jar包元數(shù)據(jù), 也包含應(yīng)用簽名.

安裝應(yīng)用

adb install -r ~/Desktop/Pedometer.apk

-r表示強(qiáng)制安裝, 會(huì)覆蓋當(dāng)前版本.

查看手機(jī)中的所有應(yīng)用信息

adb shell pm list packages -f

導(dǎo)出手機(jī)中的apk

adb pull -p /data/app/me.chunyu.Pedometer-1/base.apk ~/Desktop/base.apk
導(dǎo)出

aar類型和apk相似, 在aar中, AndroidManifest是可顯示的XML文件, 資源都在res文件夾中, 作為項(xiàng)目的庫使用.

2. aapt

aapt表示Android Assets Packaging Tool, 即Android屬性打包工具, 導(dǎo)入命令行.

在Android SDK的build-tools文件夾中, 如

ANDROID_SDK_HOME/build-tools/23.0.2

Android項(xiàng)目的Gradle中, 通過buildToolsVersion設(shè)置版本, 參考, 主要負(fù)責(zé)apk的編譯.

獲取apk信息

aapt list base.apk // 內(nèi)容
aapt dump badging base.apk // 屬性
aapt dump permissions base.apk // 權(quán)限
aapt dump resources base.apk // 資源

獲取二進(jìn)制xml信息

aapt dump xmltree base.apk AndroidManifest.xml

3. dex2jar

dex2jar是dex轉(zhuǎn)換jar的工具, 導(dǎo)入命令行, 還需要使用Java包解析工具JD-GUI. 可以分析Apk的崩潰信息, 參考.

配置d2j-dex2jar.sh命令行:
改變d2j-dex2jar.shd2j_invoke.sh的權(quán)限, 即chmod 777 xx.sh.
軟鏈接: ln -s /.../Installations/dex2jar-2.0/d2j-dex2jar.sh d2j-dex2jar.sh.

轉(zhuǎn)換apk為jar包

d2j-dex2jar.sh -f -o classes.jar base.apk

轉(zhuǎn)換過程中, 如果發(fā)生內(nèi)存不夠, 修改d2j_invoke.sh的虛擬機(jī)配置.
java -Xms512m -Xmx1024m -classpath "${_classpath}" "$@"

使用JD-GUI打開jar包, 資源都被替換為數(shù)字.


JD-GUI

轉(zhuǎn)換jar包為dex

d2j-jar2dex.sh -f -o classes.dex classes.jar

壓縮dex為apk

zip -r my.apk classes.dex

注意現(xiàn)在的apk是無法安裝入手機(jī)的, 因?yàn)闆]有簽名.
即使簽名也會(huì)報(bào)錯(cuò). 通過apktool替代打包.

4. apktool

解析apk的第三方工具, 安裝方式參考.

Mac OS X:
1. Download Mac wrapper script (Right click, Save Link As apktool)
2. Download apktool-2 (find newest here)
3. Rename downloaded jar to apktool.jar
4. Move both files (apktool.jar & apktool) to /usr/local/bin (root needed)
5. Make sure both files are executable (chmod +x)
6. Try running apktool via cli

配置成功


apktool

示例rgb_tool.apk下載, 源碼.

解析apk

apktool d rgb_tool.apk

rgb_tool文件夾, 內(nèi)容:
apktool.yml: apk屬性.
AndroidManifest.xml: 清單文件, 非二進(jìn)制.
original: 原始數(shù)據(jù), 應(yīng)用的二進(jìn)制清單和簽名.
res: 資源文件.
smali: dex解析的代碼.

smali是dex虛擬機(jī)的解析格式, 參考. 在dex2jar中, 也包含smali格式的轉(zhuǎn)換.

構(gòu)建apk. 在rgb_tool/rgb_tool/dist中生成apk文件.

apktool b rgb_tool

安裝時(shí), 會(huì)顯示未簽名.

Failure [INSTALL_PARSE_FAILED_NO_CERTIFICATES]

添加apk簽名

jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore ~/.android/debug.keystore -signedjar rgb_tool.apk rgb_tool.apk androiddebugkey
zipalign -v -f 4 rgb_tool.apk rgb_tool_align.apk

使用系統(tǒng)默認(rèn)簽名, 或者添加自己的簽名, zipalign用于對(duì)齊應(yīng)用, 建議使用. 參考.

顏色
接著, 我們來解析包, 修改一些顏色, 再生成包.
找到系統(tǒng)顏色, 修改rgb_tool/res/values/colors.xml, 主題粉色.

<color name="primary">#ffff1493</color>

圖標(biāo)
替換應(yīng)用圖標(biāo), AndroidAssetStudio創(chuàng)建圖標(biāo). 替換mipmapic_launcher.png.

圖標(biāo)

圖片
替換資源, 把背景圖片換了. 替換drawable-xxxhdpi-v4中的robot.png.

圖片

資源
替換字符串, 在strings.xml創(chuàng)建新的字符串,

<string name="action_common_skip_wcl">CLWang</string>

res/values/public.xml中替換action_common_skipaction_common_skip_wcl.

<public type="string" name="action_common_skip_wcl" id="0x7f070017" />
文字

public.xml是資源映射, smali文件使用, 類似R.java.

apktool是非常強(qiáng)大的逆向工程工具, 一定要熟練掌握.

5. androguard

源碼, 下載.

這個(gè)是一個(gè)命令行處理庫, 開發(fā)時(shí)間很早了, 就不做深入講解了.


逆向工程的基本工具, aapt\dex2jar\apktool\androguard都已經(jīng)介紹了, 根據(jù)需求選擇好用的工具吧.

OK, that’s all. Enjoy it!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,908評(píng)論 6 541
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,324評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,018評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,675評(píng)論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,417評(píng)論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,783評(píng)論 1 329
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,779評(píng)論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,960評(píng)論 0 290
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,522評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,267評(píng)論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,471評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,009評(píng)論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,698評(píng)論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,099評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,386評(píng)論 1 294
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,204評(píng)論 3 398
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,436評(píng)論 2 378

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