Android 代码混淆及反编译方法

2014-11-24 12:58:02 · 作者: · 浏览: 2

在Android SDK中自带有proguard代码混淆器,但在默认的情况下该混淆器是没有打开的。该混淆器在SDK中的路径是android-sdk-windows\tools\proguard


启动android-sdk-windows\tools\proguard\lib\proguardgui.jar可以使用独立UI的proguard。


ProGuard是一个免费的java类文件压缩,优化,混淆器.它探测并删除没有使用的类,字段,方法和属性.它删除没有用的说明并使用字节码得到最大优化.它使用无意义的名字来重命名类,字段和方法.


ProGuard的使用是为了:


1.创建紧凑的代码文档是为了更快的网络传输,快速装载和更小的内存占用.


2.创建的程序和程序库很难使用反向工程.


3.所以它能删除来自源文件中的没有调用的代码


4.充分利用java6的快速加载的优点来提前检测和返回java6中存在的类文件.


Eclipse中使用proguard的方法如下:


1.启动代码混淆功能


新建Android项目工程里面默认是带有proguard.cfg的代码混淆配置文件,如果没有请从其它项目中copy一个过来。代码混淆功能默认是没有启动这个配置的,需要手动地在项目根目录default.properties文件里面添加指定这个配置文件如下:



由于在 Debug下,不可能会有人会混淆代码,因此这只在release中有效。使用签名和无签名的方式都可以发布APK包。


这时候生成的apk,我发现是比debug版本(\bin目录下面)的要小。



二、反编译方法


反编译APK包步骤如下:


1.使用 dex2jar 把apk中的dex转为jar,解压apk得到classed.dex,执行下面的命令:


D:\dex2jar-0.0.7.7-SNAPSHOT>dex2jar.bat classes.dex


生成classes.dex.dex2jar.jar


2.用 jd-gui 进行反编译查看classes.dex.dex2jar.jar包,如下图。