美文网首页
android 未混淆反编译

android 未混淆反编译

作者: CreScert | 来源:发表于2020-05-08 18:16 被阅读0次

    参考网址:
    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 <apkPath> -o <folderPath>,参数具体的意思可以直接打apktool回车(windows)查看帮助

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

    最后的结果是:


    image.png

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


    image.png

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

    收工,有问题欢迎指出~

    相关文章

      网友评论

          本文标题:android 未混淆反编译

          本文链接:https://www.haomeiwen.com/subject/jgxqnhtx.html