Android APK 反编译
最近在做一个 app 的爬虫,发现密码竟然是加密的,模拟登录做不了,就想研究一下 Android APK 的反编译,把加密算法拿出来,发现不难。
使用工具
apktool
dex2jar
jd-gui
工具介绍
apktool
作用:资源文件获取,可以提取出图片文件和布局文件进行使用查看
dex2jar
作用:将 apk 反编译成 Java 源码(classes.dex 转化成 jar 文件)
jd-gui
作用:查看 APK 中 classes.dex 转化成出的 jar 文件,即源码文件
反编译流程
反编译获取资源文件
下载上述工具中的 apktool,解压得到 3 个文件:aapt.exe,apktool.bat,apktool.jar ,将需要反编译的 APK 文件放到该目录下,
打开命令行界面(运行-CMD) ,定位到 apktool 文件夹,输入以下命令:
apktool d [-s] -f <apkPath> -o <folderPath> |

APK 反编译得到 Java 源代码
将要反编译的 APK 后缀名改为 .rar 或 .zip,并解压,得到其中的额 classes.dex 文件(它就是 java 文件编译再通过 dx 工具打包而成的),将获取到的 classes.dex 放到之前解压出来的工具 dex2jar 文件夹内
在命令行下定位到 dex2jar.bat 所在目录,输入 dex2jar.bat classes.dex,效果如下:

在改目录下会生成一个 classes_dex2jar.jar 的文件,然后打开工具 jd-gui 文件夹里的 jd-gui.exe ,之后用该工具打开之前生成的 classes_dex2jar.jar 文件,便可以看到源码了,效果如下:

嘿嘿,加密算法也就这样找到了。