APK反编译

2020-08-22  本文已影响0人  魔女小姐的猫

概念

由于Google Android平台选择了Java Dalvik VM的方式,使其程序很容易破解和被修改。反编译是破解的途径之一,通过反编译,可以推导出他人APP产品的思路、原理、结构、算法、处理过程、运行方法等设计要素,某些特定情况下可能推导出源代码。这也给一些不法分子以可乘之机。他们对流行的APP进行反编译后,窃取正版开发者的创意或算法,再重新生成新的APP,严重侵害了正版开发者的权益。

一. 工具介绍

二. Apk反编译流程

    • 为了方便进行反编译,我们将上述下载好的3个工具统一放到一个文件夹中
      下载后的文件夹
  1. 使用apktool反编译apk得到图片、XML配置、语言资源等文件

三. 使用dex2jar反编译apk得到Java源代码

  1. 将要反编译的APK后缀名改为.rar或者 .zip,并解压,得到其中的classes.dex文件(它就是java文件编译再通过dx工具打包而成的)

    后缀名改为.rar或者 .zip,得到其中的classes.dex文件
  2. 将获取到的classes.dex放到之前解压出来的工具【dex2jar-2.0】文件夹内

    将获取到的classes.dex放到之前解压出来的工具【dex2jar-2.0】文件夹内
  3. 在命令行下定位到dex2jar.bat所在目录,输入"d2j-dex2jar classes.dex",

    在命令行下定位到dex2jar.bat所在目录,输入"d2j-dex2jar classes.dex"
    我的文件夹
  4. 命令执行完成之后,在当前目录下就可以看到生成的Jar文件了

    命令执行完成之后,在当前目录下就可以看到生成的Jar文件了
  5. 反编译classes.dex得到classes-dex2jar.jar文件之后,就可以使用【jd-gui】工具将class文件反编译成java源代码了

    反编译classes.dex得到classes-dex2jar.jar文件之后,就可以使用【jd-gui】工具将class文件反编译成java源代码了
  6. 使用jd-gui打开classes-dex2jar.jar就可以看到源代码了

    使用jd-gui打开classes-dex2jar.jar就可以看到源代码了
    注意:JD-GUI虽然可以将class反编译成java源代码,但是对于一些被混淆过的class,反编译的效果就不是那么理想了,被混淆过的class反编译后的效果图(类文件名称以及里面的方法名称都会以a,b,c....之类的样式命名):
    被混淆过的class反编译后的效果图
上一篇 下一篇

猜你喜欢

热点阅读