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文件里面添加指定这个配置文件如下:
- # Project target.
- target=android-7
- # set proguard.config
- proguardproguard.config=proguard.cfg
由于在 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包,如下图。