Android应用开发过程中,一般会加入各种日志打印,便于代码调试,android.util.Log的方法经常被使用。如果应用总是在后台不断的输出Log.i或Log.d的内容,除了增加系统开销外,对应用的整体效率受影响。ProGuard通过删除从未用过的代码和使用晦涩名字重命名类、字段和方法,对代码进行压缩,优化和混淆。结果生成一个比较小的.apk文件,该文件比较难进行逆向工程,因此安全性较高。
1 基础配置
在Eclipse中新建一个Android工程,一个proguard-project.txt文件会在工程的根目录下自动创建。默认情况下,Eclipse中的新建工程不会加入ProGuard功能,需要修改project.properties文件。即将“#proguard.config=…”前端的“#”去掉就可以了。“proguard.config=”的配置信息由两部分组成:默认部分和工程特有部分,工程特有部分将附加到默认部分(如下图提示),共同组成工程的混淆配置,因此如果需要根据需求配置混淆文件,只需要修改proguard-project.txt。
2 优化日志
默认情况下,上一节的配置没有优化功能,因此我们应该将project.properties文件中的“${sdk.dir}/tools/proguard/proguard-android.txt”替换为“${sdk.dir}/tools/proguard/proguard-android-optimize.txt”,这样优化功能才没有被关闭。
优化日志主要是通过如下命令实现:
-assumenosideeffects class_specification
这个命令指出了哪些方法是无副作用的。在优化阶段,此命令将会去除这些方法的调用。
3 实例
按照以上介绍的步骤和方法,新建工程,并配置ProGuard,在proguard-project.txt文件中新增如下指令。
-assumenosideeffects class android.util.Log { public static int v(...); public static int i(...); public static int w(...); public static int d(...); }
需要注意的是,在Eclipse里的Run或BuildProject/Build All来生成Apk,是不会混淆代码的!“Export UnsignedApplication Package...”,然后按照向导操作即可,最终生成了不签名的Apk。查看效果可以用7z等压缩程序打开,将其中的classes.dex解压,用dex2jar转成jar格式后,再用Java反编码工具jd-gui打开,就会看到代码的混淆效果。