apk反编译步骤
2011-02-24 21:17:25
标签:apk 反编译 休闲 Android 职场
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。lbrant.blog.51cto/2400264/499893
对于软件开发人员来说,保护代码安全也是比较重要的因素之一,不过目前来说Google Android平台选择了Java Dalvik VM的方式使其程序很容易破解和被修改,首先APK文件其实就是一个MIMEZIP的压缩包,我们修改ZIP后缀名方式,然后解压缩可以看到内部的文件结构,类似Sun JavaMeJar压缩格式一样,不过不同的是Android上的二进制代码被编译成为Dex的字节码,所有的Java文件最终会编译进该文件中去,作为托管代码既然虚拟机可以识别,那么我们就可以很轻松的反编译。所有的类调用、涉及到的方法都在里面体现到,至于逻辑的执行可以通过实时调试的方法来查看,当然这需要借助一些我们自己编写的跟踪程序。Google最然在Android Market上设置了权限保护app-private文件夹的安全,但是最终我们使用修改定值的系统仍然可以获取到需要的文件。
当然了,我们反编译的目的是为了学习。
1. Apk文件:自己准备apk文件。
2. xxx.apk扩展名修改为xxx.rar或者xxx.zip,用WinRar解压缩,你可以看到内部文件的结构,类似下图所示:
3. 直接打开l会发现是乱码,这里面是二进制字符,需要用AXMLPrinter2.jarle/p/android4me/downloads/list),下载AXMLPrinter2.jar文件,为了方便,这里我把它放到了Android SDK文件夹下面的tools文件夹中)
4. 逆向xml文件:把相应的l放到AXMLPrinter2.jar同一目录,进入命令行模式,输入以下命令(注意空格):
java -jar AXMLPrinter2.l -&
5. 然后,打开,你就可以看到相应内容了,但是对资源的引用:android:label="@7F080000" android:icon="@7F02002A"(这个是编译后对应资源R.java中的值),对一些属性值的设置:android:configChanges="0x000000A0",还有:android:textColor="?android:01010036" android:textColor="?android:01010212",这个还需要查SDK,看到有android字样,就知道是系统定义的常量,在android sdk Reference 页面搜索01010036,"?android:01010036" 对应 "?android:attr/textColorSecondary","?android:01010212"对应 "?android:attr/textColorTertiary"
6. 在解压缩后的文件夹中,你会发现还有一个classes.dex文件,这是编译 后最终生成的dalvik字节码,还需要另外一个工具dex2jar(下载地址:le/p/dex2jar/downloads/list),将Android’s .dex format转换成Java’s .class format,下载后解压后有一个dex2jar.bat文件,把你的classes.dex文件拷贝到该目录中,命令行切换到该目录,运行命令dex2jar.bat classes.dex,将会在目录中生成classes.dex.dex2jar.jar文件。
7. 最后,还需要用工具去查看反编译的类,下载JD-GUI工具(绿无须安装,下载地址:java.decompiler.free.fr/?q=jdgui),将jar文件拷贝到GUI文件夹下,运行JD-GUI,打开这个Jar文件,就能看到相应的类了,同样里面有许多很长的数字。
然而,我们发现上述方法对资源文件(drawablexml等),反编译的不够完美,在一些工具中,用到了apktool,可以从le/p/android-apktool/下载(Windows下需要ar.bz2apktool-install-windows-r04-brut1.tar.bz2两个文件),下载后解压,为了以后方便使用,可以把得到的3个文件都复制到某个文件夹(比如
D:\workspace\apktool)下,使用步骤如下:
打开命令行窗口,切换到你复制到的目录,或者直接把目录路径添加到环境变量中;
1)apktool d X.apk Y
反编译X.apk到文件夹Y
例如在命令行窗口输入"apktool d E:\game.apk E:\game_out"(不包含引号),就会启动apktool反编译E盘根目录下的game.apk文件,反编译得到的文件放在到E:\game_out\文件夹。
2)apktool b Y
从文件夹Y重建为APK,输出到Y\dist\out.apk
例如"apktool b E:\game_out",将E:\game_out文件夹下的文件编译成新的apk文件,新文件会放在E:\game_out\dist\目录下,文件名为out.apk


其他参数,请输入apktool -help查看,经过反编译后,
classes.dex文件被反编译为smali文件夹下的文件;
resources.arsc被分解成若干xml文件,放在res文件夹下;
apk中原有的xml文件也变转换为可以直接用文本编辑器查看的形式。
其他的文件会被解压到相应的文件夹。
[2] [匿名]learnAndroid 回复
2011-04-28 11:16:08
这句都写错了,java –java AXMLPrinter2.l-&
不知楼主有没有试过
正确: java -jar AXMLPrinter2.l ->
注意空格
XP和WIN7搭建Android开发环境步骤详细图解
|
浏览:2715
|
更新:2013-08-03 15:16
|
标签:windows7 android
开始Android开发之前,首先要搭建开发环境,XPWIN7搭建Android开发环境步骤比较复杂,大家可以按照下面的步骤一步一步按部就班的进行安装。
1. JDK安装:1)先下载JDK;(2)设置环境变量步骤如下:
我的电脑->属性->高级->环境变量->系统变量中添加以下环境变量:
JAVA_HOME值为: D:\Program Files\Java\jdk1.6.0_18(你安装JDK的目录)
CLASSPATH值:.;%JAVA_HOME%\lib\tools.jar;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\bin;
Path: 在开始追加 %JAVA_HOME%\bin;
NOTE:前面四步设置环境变量对搭建Android开发环境不是必须的,可以跳过。
安装完成之后,可以在检查JDK是否安装成功。打开cmd窗口,输入java –version 查看JDK的版本信息。出现类似下面的画面表示安装成功了:
2. Eclipse安装:
如果你还么有Eclipse的话,可以去这里下载,下载如下图所示的Eclipse IDE for Java Developers92M)的win 32bit版:解压之后即可使用。
3. Android SDK安装:
Android Developers下载android-sdk_r05-windows.zip,下载完成后解压到任意路径。运行,点击Available Packages。如果没有出现可安装的包,请点击Settings,选中Misc中的"Force ..."这项,再点击Available Packages
选择希望安装的SDK及其文档或者其它包,点击Installation SelectedAccept AllInstall Accepted,开始下载安装所选包在用户变量中新建PATH值为:Android SDK中的tools绝对路径(本机为D:\AndroidDevelop\android-sdk-windows\tools)。
确定后,重新启动计算机。重启计算机以后,进入cmd命令窗口,检查SDK是不是安装成功。android模拟点击 运行 android –h 如果有类似以下的输出,表明安装成功:
4. ADT安装:
打开 Eclipse IDE,进入菜单中的 "Help" -> "Install New Software"
点击按钮,弹出对话框要求输入NameLocationName自己随便取,Location输入le/android/eclipse。如下图所示:确定返回后,在work with后的下拉列表中选择我们刚才添加的ADT,我们会看到下面出有Developer Tools,展开它会有Android DDMSAndroid Development Tool,勾选他们。 如下图所示:
然后就是按提示一步一步next。完成之后:选择Window >
在左边的面板选择Android,然后在右侧点击并选中SDK路径,本机为: D:\AndroidDevelop\android-sdk-windows点击ApplyOK。配置完成。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。