網(wǎng)站首頁 編程語言 正文
這幾天在上海出差,忙里偷閑學習了一下Apk的反編譯工具的基本使用。下面就簡單介紹一下如何將我們從網(wǎng)上下載的Apk文件進行反編譯得到我們想要獲得的資源文件和源碼。
一、Apk文件組成
Android的應(yīng)用程序APK文件說到底也是一個壓縮文件,那么可以通過解壓縮得打里面的文件內(nèi)容,不過很顯然,當你去解壓完去查看的時候,發(fā)現(xiàn)里面的很多東西和你想象中的不太一樣。資源文件等xml文件基本打不開,即使打開了也都是亂碼(而這正是Android進行加密過),有些應(yīng)用會將圖片資源等的也加密(如qq音樂)。
而既然直接解壓無法看到正常的應(yīng)用程序,那么就需要借助反編譯軟件來實現(xiàn)APK的反編譯。
二、反編譯必備工具及使用
Android工程文件主要有資源文件和源代碼組成。而為了查看資源文件需要借助一個工具,本文使用的是apktool工具進行反編譯,經(jīng)過編譯后能夠正確查看XML文件和其他的非XML的資源文件,這對于漢化而言有著巨大的意義。而為了查看源碼,則需要借助于dex2jar和jd-gui這兩個工具,其中dex2jar工具負責將dex文件轉(zhuǎn)化為jar文件,而jd-gui則用于查看jar文件。
1)apktool
一次失敗的經(jīng)歷-----使用apktool時報錯
原因:apktool的版本過低,無法解析當前版本的apk。
修正:
更新最新的apktool版本后正常,本文使用的最新apktool版本為2.2.2.
然后就可以發(fā)現(xiàn)資源文件等xml文件可以正常打開。
2)Dex2jar?
接下來就需要對source code進行反編譯。
需要借助工具Dex2jar和jd-gui。其中Dex2jar,顧名思義就是將dex文件反編譯為jar文件。而jd-gui則用于直接查看jar包中的源代碼。
具體步驟就是將apk文件解壓,得到其中的classes.dex,它就是java文件經(jīng)過編譯而后通過dx工具打包而成的,而后解壓下載的dex2jar,將classes.dex復制到dex2jar根目錄下,在命令行下定位到該目錄下,運行d2j-dex2jar.bat classes.dex classes.dex
可以發(fā)現(xiàn)得到一個classes-dex2jar.jar文件。這個文件就是我們需要得到的source code。
3)jd-gui
接下來需要在jd-gui中瀏覽該文件,這個就是最終的結(jié)果
當然,你也發(fā)現(xiàn)了這些源碼都是被混淆了的,即用無意義的字母來重命名類、成員變量、方法和屬性以及刪除沒用的注釋。
三、Apk的加密過程
既然都提到了這里了,我們也順便了解一下Android Apk的加密過程。
由于Java字節(jié)碼的特殊性,使得它非常容易被反編譯,(正如剛才我們進行的那些操作,借助一下工具就反編譯了一個QQ音樂的Apk),因此,顯然我們會有一些保護措施,對編譯好的Class文件進行一些保護。通常我們都會使用ProGuard來對Apk進行混淆處理,用無意義的字母倆重命名類、成員變量、方法和屬性。(當然它能刪除一些無用的類、成員變量、方法和屬性以及刪除沒用的注釋,最大程度優(yōu)化字節(jié)碼文件)
而現(xiàn)在我們一般都采用Android Studio作為開發(fā)平臺,在該平臺下可以很方便的使用ProGuard,在Gradle Script文件夾下,打開build.gradle(Module:app)文件,顯示如下:
這里的minifyEnable即為控制是否啟動ProGuard的開關(guān),設(shè)置為true則開啟ProGuard進行混淆和優(yōu)化。
而proguardFiles分為兩部分,前半部分是一個系統(tǒng)默認的混淆文件,位于SDK目錄下的tools/proguard/proguard-android.txt,一般情況下使用這個默認的文件即可,另一部分是項目中自定義的混淆文件,可以在項目中的App文件夾中找到這個文件,在這個文件夾中可以定義引入的第三方依賴包的混淆規(guī)則。配置好ProGuard后,只要使用AS導出Apk,即可生成混淆后的字節(jié)碼文件。
原文鏈接:https://www.cnblogs.com/zhangyingai/p/7087373.html
相關(guān)推薦
- 2022-11-30 C語言中順序棧和鏈棧的定義和使用詳解_C 語言
- 2023-08-30 Git忽略已經(jīng)提交過一次文件Git忽略文件
- 2024-03-01 解決 “TypeError: Cannot read properties of undefined
- 2023-01-01 c語言實現(xiàn)計算圓周率的近似值_C 語言
- 2022-08-27 golang?隨機數(shù)的兩種方式_Golang
- 2022-09-13 Nginx如何配置根據(jù)路徑轉(zhuǎn)發(fā)詳解_nginx
- 2022-06-16 Golang項目搭配nginx部署反向代理負載均衡講解_Golang
- 2022-10-26 使用Go?http重試請求的示例_Golang
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支