Android 代码混淆及反编译方法

一、AndroidSDK自带proguard混淆

在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文件里面添加指定这个配置文件如下:

  1. # Project target.  
  2. target=android-7  
  3. # set proguard.config  
  4. proguardproguard.config=proguard.cfg  
2.打包发布APK

由于在 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包,如下图。

 Android 代码混淆及反编译方法

相关推荐