关于APK,DEX的介绍
当我们编译一个安卓项目的时候,整个项目会被打包成一个 apk文件。这个文件其实是一个标准的zip文件,因此可以用解压缩工具打开。这个apk文件一般都包含程序的代码(在classesdex文件中), 资源文件, 证书, manifest 文件等。 其中对我们最重要的是classesdex文件,因为编译后的字节码(bytecode)都是放在这个文件中。我们后面讲的反编译就是针对这个dex文件来的。
反编译普通的APK文件:
对于普通的APK/DEX文件的反编译,其实工具有很多, 包括:
ByteCode Viewer: 一个可视化的集成工具,说实话,不太好用,不够稳定,生成代码质量中等。
dex2jar + jd_gui: 这两个工具组合还可以, 用起来比ByteCode Viewer麻烦一些,但比较稳定,生成代码质量中等。
在线反编译工具JADX: >
反编译ODEX文件:
Android 50 Lollipop以后,Google用ART代替了以前的Dalvik,对于普通的app来说我们仍然可以用上面的方法来把dex文件反编译成Java源代码。但对于系统预装的App,特别是类似应用商店,播放器等, 你会发现这些应用的apk文件中找不到对应的classesdex文件,而是会发现在其子目录下有个odex文件。 那如何反编译这个odex文件呢?我通过google查了查,知道应该用baksmali,但从github上下载了几个版本都不行,报各种不同错误。经过反复搜索和尝试,终于找到了这篇文章
: >
1 从这里下载工具包, 解压缩到本地。 这里的baksmali的版本是203 不同版本的baksmali针对的Android内核不同。有时候高版本反倒不好用。
2 打开工具所在目录, 按住shift键, 点击鼠标右键,打开windows命令窗口
3 把 odex文件拷贝到该目录
4 在命令窗口运行: oat2dexbat odex 正常情况下,应该显示OK等信息。如果报错的话,说明这个文件无法转换,后面的也不用试了。
5 运行 oat2dexbat odex tempdex 运行后会创建一个tempdex文件。
6 运行 java -jar baksmali-203jar -a 21 -x tempdex -o source 运行后会创建一个source的文件夹,并将tempdex反编译到该文件夹。-a 21 表明的是Android内核的版本21
7 运行 java -jar small-203jar -a 21 source -o classesdex , 反编译为classesdex文件。
需要注意的是:由这种方式反编译成的classesdex 文件相比原生的classesdex 还是缺少了些信息,因此反编译这种classesdex 文件后生成的java代码可读性会更差些。
8 用在线工具JADX 来把 classesdex 最终反编译为java代码。
首先下载apktool工具(apktool-install-windows-r04-brut1tarbz2和apktool141tarbz2)
apktool工具下载见附件。
得到如下文件:
2 下载完成后,解压apktool-install-windows和apktool得到文件aaptexe,
zapktoolbat,apktooljar。
3 然后我们把我们要反编译的apk文件(MyPolygonapk)拷贝到apktool目录下
4 打开一个命令行窗口,进入apktool目录下,输入如下命令:
apktoolbat d MyPolygonapk f:\mypolygon /命令行解释:apktool d [要反编译的apk文件 ] [输出文件夹]/
5 这样在F盘的mypolygon就得到了我们想要的资源文件。mypolygon文件夹应该是不存在的文件夹,此命令会自动生成mypolygon文件夹;如果是已有文件夹,命令行会提示你添加-f 参数强制覆盖该文件夹。通过以上命令我们得到如下文件:
apk文件复制到SD卡。
命令序列如下:
文件夹到Android的SDK / tools目录
输入adb的外壳
进入苏
输入cd数据
输入CD的应用程序
然后,你可以看到所有你安装apk文件。输入相应的apk位CP / SD卡/
的apk文件,因此它会被复制了一个空格。
直接进入apk文件扩展名rar格式,你可以看到目录熟悉的结构,
xml文件后打开是二进制的,不能观看。
然后他们使用AXMLPrinter2工具android4me。 (你自己百度搜索)
输入以下命令来解析XML文件出来
此命令是在命令行Java的罐子AXMLPrinter2jar showtimes_listxml
鉴于此showtimes_listxml 该showtimes_listxml生成xml文件,输入以下命令:
Java的罐子AXMLPrinter2jar showtimes_listxml> hxml
持续到这一点,只看到xml文件的内容,其中工程在java源文件还是看不到,看到classesdex文件目录结构,我们需要DEX文件转换成jar文件。
这里使用的另一种工具dex2jar。 (自搜索下载)解压后显示在Windows下
目录如下:
在命令行中,输入这个目录:
在Windows下,输入以下命令: dex2jarbat C:\ classesdex
在C盘运行完成后会多一个classesdexdex2jarjar文件,这就是我们所需要的jar文件。
使用JD-GUI,的jar文件的java代码的逆向工程。 (请搜索下载)
它进入Windows,Linux和最大三个版本,这里我下载的Windows版本。
解压,双击运行exe文件后,选择相应的jar文件的Java文件的文件classesdexdex2jarjar显示反向工程了!
以上就是关于如何反编译Android 的apk/dex/odex,获得源码全部的内容,包括:如何反编译Android 的apk/dex/odex,获得源码、如何反编译android的apk文件得到资源文件、android破解apk后使用jd软件怎么导出源码等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)