android 未混淆反编译

参考网址:
https://blog.csdn.net/qq_33721320/article/details/94553756
https://www.cnblogs.com/f839903061/archive/2012/11/26/2788819.html
https://blog.csdn.net/qq_32452623/article/details/54291412

故事的起因是因为我一个未提交的布局A,由于要新画界面B,没有拷贝A直接更改了布局文件A,反应过来的时候布局A已经撤回不去了。。。。但是界面懒得再画一遍了。就想到了之前运行的包(因为 每次运行项目时都会在app/build/bakApk/目录下保存一份debug包),这时候只要拿到包就可以了,吗?

当打开后发现布局文件全是乱码...

在寻找的过程中顺便学了下反编译..

先说简单的,反编译清单文件(以下都是未混淆的代码前提下反编译,混淆过的下面方法没有用~~~~~)

说之前,先把需要的工具都说明下,由于有的工具下载比较困难,所以我提交到github上面,需要的盆友可以下载下来自行保存:https://github.com/CreScert/androidtool

image.png

1.反编译清单文件
需要的工具是:AXMLPrinter2.jar,也就是 pconline1482113373043.zip
下载下来后,把需要反编译的清单文件和AXMLPrinter2.jar放在同一个目录,打开命令行进到此目录,输入

java -jar AXMLPrinter2.jar AndroidManifest.xml 
image.png

反编译清单文件就完成了。

下面是反编译下Apk类

2.反编译Apk类
需要的工具是:dex2jar(dex2jar-2.0.zip) 和 JD-GUI(jdguiwindows.zip)

备注:前者是将apk中的classes.dex转化成Jar文件,而JD-GUI是一个反编译工具,可以直接查看Jar包的源代码。

使用
1.首先将apk文件,将后缀改为zip,解压,得到其中的classes.dex,它就是java文件编译再通过dx工具打包而成的;
2.解压下载的dex2jar,将classes.dex(最好将classes1..2..3.都拿过来)复制到dex2jar.bat所在目录。在命令行下定位到dex2jar.bat所在目录
3.输入:

dex2jar.bat classes.dex 

如果没有dex2jar.bat,使用d2j-dex2jar.bat就行:

d2j-dex2jar.bat classes.dex 

生成 classes.dex.dex2jar.jar

image.png

运行JD-GUI(jd-gui.exe),打开上面生成的jar包,即可看到源代码了。

下面是反编译下布局文件:

3.反编译布局文件

需要工具:aapt.exe,apktool.bat,apktool.jar
其中:aapt.exe在android sdk\build-tools\里面随便一个版本的aapt即可。

apktool在貌似2之前的和2之后的不一样,如果是2之后的就用下面的方法,之前的我没处理过~

apktool.bat的内容如下:

@echo off
if "%PATH_BASE%" == "" set PATH_BASE=%PATH%
set PATH=%CD%;%PATH_BASE%;
chcp 65001 2>nul >nul
java -jar -Duser.language=en -Dfile.encoding=UTF8 "%~dp0\apktool.jar" %*

apktool.jar这个因为翻墙不好下载的去网上下载即可,记得下载2版本以后的。下载好后记得更改文件名为apktool.jar

最后是这三个:


image.png

网上说最好放在C盘,我们就放在C盘,将apk放在C盘的根目录(哪里都行,输对就行)

apktool d -f c:\app.apk -o c:\app_output\

注意这里的语法,网上有好多是 apktool d c:\app.apk c:\app_output\,这样会报错:
Input file (c:\app_output) was not found or was not readable.

image.png

解决办法:是因为apktool升级到2.0以上时,使用方式已经替换,格式为:apktool d [-s] -f -o ,参数具体的意思可以直接打apktool回车(windows)查看帮助

说明:apktool d [-s] -f apk的位置 -o 最后生成的目录(这个是目录哦~)
-f 是强制覆盖已经存在的目录。

最后的结果是:


image.png

最后提示个小技巧:3步骤生成的布局文件中的android:id是@id/格式的,不是@+id/格式的。


image.png

可以用记事本的替换功能:
android:id="@id/ 替换为 android:id="@+id/

收工,有问题欢迎指出~

2023年7月18日更新
又发现一个比较友好的工具,可以一次性全都解开:Jadx-gui。
地址是:https://github.com/skylot/jadx/releases
使用方法就是把apk包拖进去就行。

你可能感兴趣的:(android 未混淆反编译)