什么是 Android 逆向开发?
Android 逆向开发是指对已发布的 Android 应用进行分析和破解,以了解应用程序的内部工作原理,获取应用程序的敏感信息,或者修改应用程序的行为。逆向开发可以帮助开发人员了解他人的代码实现,也可以帮助黑客攻击应用程序。
APKTool 是一个开源的、跨平台的反编译、回编译 Android 应用程序的工具。它能够将 APK 文件解压并还原成 Android 应用程序的资源文件和 Smali 代码,还能将修改后的资源文件和 Smali 代码重新打包成 APK 文件。APKTool 是 Android 应用程序开发和逆向开发的重要工具之一,它能够帮助开发者对 APK 文件进行修改、分析和定制,也能够帮助安全研究人员和黑客对应用程序进行逆向工程和漏洞分析。
APKTool 的主要功能包括
APKtool官网:https://ibotpeaches.github.io/Apktool/
APKtool下载:https://bitbucket.org/iBotPeaches/apktool/downloads/
APKtool源码:GitHub - iBotPeaches/Apktool: A tool for reverse engineering Android apk files
打开一个新的浏览器窗口。
复制以下链接:
https://raw.githubusercontent.com/iBotPeaches/Apktool/master/scripts/windows/apktool.bat
右键点击,选择“另存为”,并将其保存为一个名为apk_run.bat的文件。
作者已经整理了一份:放在:软件包/apktool目录下
访问apktool的GitHub页面:
https://github.com/iBotPeaches/Apktool
在页面上,您通常会看到一个“下载”或“releases”选项。点击它,然后选择最新版本的apktool
下载zip文件或tar文件。
Github 直达链接:github.com/iBotPeaches…]
(https://github.com/iBotPeaches/Apktool)
找到 Releases 选项并点击
我们可以看到 apktool 最新版本是 2.7.0 版本
找到 Assets 区域,找到 apktool_2.7.0.jar Jar 包进行下载
解压您刚下载的文件(如果需要)。
在解压后的文件中,找到jar文件。
将其重命名为apktool.jar。
(任意目录都可以)
打开文件资源管理器。
导航到C:\Windows目录(这通常是Windows的安装目录)。
将apktool.jar和apktool.bat复制或移动到这个目录中。
如果您没有直接访问C:\Windows的权限,或者想在其他位置安装apktool,您可以将其添加到系统的PATH环境变量中。这样,您就可以在任何目录下访问它。
按Win + Pause/Break键打开系统属性。
选择“高级”选项卡,然后点击“环境变量”。
在“系统变量”部分,找到名为“Path”的变量,然后点击“编辑”。
在值的末尾添加apktool的目录(例如,如果它在C:\Users\YourUsername\Documents\apktool,那么添加C:\Users\YourUsername\Documents\apktool)。确保在值的末尾添加分号(;)作为分隔符。
打开命令提示符(CMD)。
输入apktool并按Enter键。如果一切正常,您应该看到apktool的帮助信息。
下载完 jar 后,找一个你想要反编译apk,然后输入以下命令即可
.\apk_run.bat d .\5_base.apk -o .\5_base
或
java -jar xxx/apktool-2.7.0.jar d xxx/test.apk -o xxx/test
这句命令的意思是,将 test.apk 进行反编译,然后输出到 test 目录下
然后我们看到到命令行输出完以下指令就证明反编译成功了
I: Using Apktool 2.7.0 on test.apk
I: Loading resource table...
I: Decoding AndroidManifest.xml with resources...
I: Loading resource table from file: /Users/xxx/Library/apktool/framework/1.apk
I: Regular manifest package...
I: Decoding file-resources...
I: Decoding values */* XMLs...
I: Baksmaling classes.dex...
I: Copying assets and libs...
I: Copying unknown files...
I: Copying original files...
然后我们看到 test 目录就生成了以下这些文件
那么 apktool 生成这些文件和目录分别是什么呢?
反编译完成后,我们可以尝试修改 apk 内容了,我们这里尝试修改 App 名字,方法也简单,在直接修改清单文件的属性值
xmlns:android="http://schemas.android.com/apk/res/android"
package="com.xxx.xxx"
platformBuildVersionCode="25"
platformBuildVersionName="7.1.1">
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="我是被反编译修改过的名字"
android:supportsRtl="true"
android:theme="@android:style/Theme.Holo.Light.DarkActionBar">
然后输入以下命令进行回编译
.\apk_run.bat b .\5_base -o .\6_base.apk
或
java -jar xxx/apktool-2.7.0.jar b xxx/test -o xxx/test2.apk
这句命令的意思是,对 test 目录进行回编译,然后输出到 test.apk 文件
I: Using Apktool 2.7.0
I: Checking whether sources has changed...
I: Smaling smali folder into classes.dex...
W: Unknown file type, ignoring: xxx/test/smali/.DS_Store
W: Unknown file type, ignoring: xxx/test/smali/com/.DS_Store
W: Unknown file type, ignoring: xxx/test/smali/com/toshiba/.DS_Store
I: Checking whether resources has changed...
I: Building resources...
I: Building apk file...
I: Copying unknown files/dir...
I: Built apk into: xxx/test2.apk
这个时候我们就可以看到 apk 已经回编译完成了,过程十分简单
Ps:如果无法进行反编译或者回编译,可以尝试以下方法
1提取高版本的 framework-res.apk(存放在 /system/framework 目录下)
2提取完后放到某个文件夹中并且重名为 1.apk,这里示例放在了 framework-res/1.apk
3在反编译或者回编译的时候,在命令尾处加入 -p xxx/framework-res/ 来指定 framework-res.apk 文件
这个时候回编译出来的 apk 还不能安装到手机上面,因为它还有没有签名,需要先进行签名,说到签名,就必须要介绍的两个工具
apksigner:是 Android SDK 自带的工具,用于给 Android 应用程序进行数字签名。该工具可以对 APK 文件进行签名、验证签名、查看签名信息等操作,可以用于保证 Android 应用程序的完整性和安全性。
这两者不同之处在于,jarsigner 只能进行 v1 签名,而 apksigner 可以进行 v1 + v2 + v3 签名,那么这几种签名方式分别有什么区别呢?
了解了 Android 相关的知识点,所以我们这里选择 apksigner 来签名。
5.0 apksigner工具从哪里找?
打开Android Studio软件
点击:file > project structure...
在Android Studio本地SDK目录中查找签名工具
java -jar C:\Users\Lenovo\AppData\Local\Android\Sdk\build-tools\34.0.0\lib\apksigner.jar sign --ks "密钥库文件路径" --ks-pass pass:"密钥库密码" --ks-key-alias "密钥别名" --key-pass pass:"密钥别名密码" --out 签名后输出的文件.apk 需要被签名的文件.apk
上面的命令解释如下:
sign:使用 apksigner 工具进行数字签名操作
--ks:指定签名证书的 keystore 文件路径
Keystore的用法,详见《安全加密基础-基础概念、keytool、openssl》
--ks-pass pass:指定签名证书的 keystore 密码
--ks-key-alias:指定签名证书的别名
--key-pass pass:指定签名证书的别名密码
--out:指定签名后的 APK 文件名
那么我如果想指定 apksigner 签名方案,需要怎么做呢?我们可以在 Android 官网 找到答案
如果我要同时签名 v1 + v2 + v3 方案,那么可以将上面的命令修改成下面这样
java -jar C:\Users\Lenovo\AppData\Local\Android\Sdk\build-tools\34.0.0\lib\apksigner.jar sign --v1-signing-enabled true --v2-signing-enabled true --v3-signing-enabled true --ks "密钥库文件路径" --ks-pass pass:"密钥库密码" --ks-key-alias "密钥别名" --key-pass pass:"密钥别名密码" --out 签名后输出的文件.apk 需要被签名的文件.apk
我如果签名完了,如何去验证 apk 签名?可以输入以下命令进行验证
java -jar C:\Users\Lenovo\AppData\Local\Android\Sdk\build-tools\34.0.0\lib\apksigner.jar sign verify -verbose -print-certs 需要验证签名的文件.apk
Verified using v1 scheme (JAR signing): true
Verified using v2 scheme (APK Signature Scheme v2): true
Verified using v3 scheme (APK Signature Scheme v3): true
Verified using v3.1 scheme (APK Signature Scheme v3.1): false
Verified using v4 scheme (APK Signature Scheme v4): false
当然还有另外一种土方子,就是在知道 apk 有签名的情况下,但是你只想知道 apk 有没有用 v2 以上的签名方案,又嫌输入命令行太麻烦,可以通过这种方式来判断:可以在 apk 根目录找到 META-INF/CERT.SF 文件,如果其文件头有 X-Android-APK-Signed 字段,证明使用了 v2 以上的签名方式,如果没有则可能使用了 v1 的签名或者没有签名。
经过上面的反编译、修改 apk 应用名称、回编译、apk 签名,我们就可以进行安装了
是不是灰常简单呢?