美文网首页
Apk反编译

Apk反编译

作者: angeliur | 来源:发表于2019-12-02 18:45 被阅读0次
    APK反编译流程

    对我们来说,apk 就是一个压缩包 。反编译 apk 就是反编译 dalvik(Dalvik 是 Google 公司自己设计用 于 Android 平台的 Java 虚拟机)二进制文件 dex 和压缩的 xml 文件 。

    常用的工具三件套:apktool + dex2jar + jd-gui

    首先了解一下,源文件到 apk 的变化,看图:


    1575276677.jpg
    • ApkTool的使用

      通过普通的压缩软件解压之后得到classes.dex和xml文件,但是xml文件都是不能看的。所以需要结合apktool来解压缩,得到可以查看的xml文件和smali文件。普通解压后的文件目录:


      普通解压.jpg

    apktool主要用于逆向apk文件。它可以将资源解码,并在修改后可以重新构建它们。它还可以执行一些自动化任务,例如构建apk。apktool解压后不仅 xml 可见,png.9 图片也可以直接使用。如果是普通解压,解压后的 png.9 图片都要自己重新加黑边。apktool解压后的文件目录:

    apktool解压.jpg

    apktool功能:

    • 将资源解码成原来的形式(包括resources.arsc,class.dex,9.png和xml)
    • 将解码的资源重新打包成apk/jar
    • 组织和处理依赖于框架资源的APK
    • Smali调试
    • 执行自动化任务

    安装方式:

    • https://ibotpeaches.github.io/Apktool/install/ 分别下载apktool.bat和apktools.jar
    • 然后将这两个文件都拷贝到安装的sdk的android-sdk-windows\platform\-tools 目录下,这样执行apktool命令的时候才能找到。

    操作方式:

    • 反编译apk文件,如下命令,可以在当前目录下得到一个和反编译的apk相同名字的文件夹,里面就是我们需要的资源文件。
    apktool d test.apk
    
    • 将反编译后的文件重新打包
    apktool b test
    
    • dex2jar的使用

      下载地址: https://github.com/pxb1988/dex2jar/releases

      操作方式:下载解压之后进入到dex2jar所在目录,有两种方式可以得到class的. jar 文件:

      • 将apk普通解压得到的classes.dex拷贝到dex2jar目录下,windows系统执行命令 d2j-dex2jar.bat classes.dex ,linux系统执行 d2j-dex2jar.sh classes.dex ,然后在当前目录下面就生成了 classes-dex2jar.jar 文件

      • 第二种方式比较简单,就是直接通过对apk执行dex2jar命令得到.jar文件,命令如下:dex2jar.bat demo.apk ,然后就生成了demo-dex2jar.jar

        jar xf demo-dex2jar.jar 命令可以提取jar文件

    • jd-gui 的使用

      下载地址:

      https://github.com/java-decompiler/jd-gui/releases 或者 http://java-decompiler.github.io/

      操作方式:

      生成.jar文件后就需要使用到 jd-gui工具,windows下双击打开,然后打开上面生成的classes-dex2jar.jar文件,或者将jar文件直接拖到jd-gui中打开。就可以查看对应的java代码,apk的代码可能进行了混淆,所以会有部分代码无法完整查看。

    相关文章

      网友评论

          本文标题:Apk反编译

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