linux下反编译android apk

一、所须要的工具
java

1)apktool,功能:反编译出apk所须要的资源文件和布局设置文件等,linux

下载地址:https://code.google.com/p/android-apktool/downloads/list
android

须要下载apktool1.5.2.tar.bz2 和apktool-install-Linux-r05-ibot.tar.bz2 这两个文件,并把解压后的文件放在同一个文件夹中。app

 

2)dex2jar,功能:反编译出jar文件,即apk的源程序文件的字节码,工具

下载地址:http://code.google.com/p/dex2jar/downloads/list布局

 

3)jdgui,功能:查看dex2jar反编译出的jar文件,使用该工具能够看到字节码对应的Java源代码,这个我在官网上没有找到,而后本身在网上下载的,但试验过能用。点击打开后,以下图所示:ui


 

二、反编译过程
1)反编译出资源文件
使用apktool工具,进入apktool所在的目录下,使用以下的命令:
    ./apktool d ./xxx.apk(apk所在的路径)
google

d表示decode,在当前目录下就会生成一个名为xxx的目录,里面就是反编译出来的各类资源文件,其中res表示资源文件,smali表示源代码,不过是字节码,不能直接查看。spa

以本人的实验为例子,以下图所示:.net

此时会在当前目录下生成一个目录app-debug。

 

2)源代码的反编译
a)由于apk文件实际上是使用zip进行打包压缩生成的文件,因此先把xxx.apk文件更名为xxx.zip文件,并对其进行解压。
b)进入解压后的目录,其中有一个classes.dex文件,这个文件就是java文件编译再经过dx工具打包而成的,源代码就包含在这个文件中。
c)把前一步生成的文件classes.dex复制到dex2jar工具的根目录中,并使用以下命令对其进行反编译:
    ./dex2jar.sh d classes.dex
就会在当前目录下生成一个classes_dex2jar.jar文件

d)点击打开jdgui工具,这是一个图形化的工具,而后打开上上述的classes_dex2jar.jar文件就能够看到apk对应的源代码。

对于本人的实验以下:

 

源代码与反编译出来的代码比较以下(白色为反编译内容,黑色为原内容):

相关文章
相关标签/搜索