码迷,mamicode.com
首页 > 移动开发 > 详细

ProGuard优化Android日志

时间:2014-07-18 13:35:32      阅读:229      评论:0      收藏:0      [点我收藏+]

标签:android   style   blog   http   java   使用   

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打开,就会看到代码的混淆效果。



ProGuard优化Android日志,布布扣,bubuko.com

ProGuard优化Android日志

标签:android   style   blog   http   java   使用   

原文地址:http://blog.csdn.net/ruyi366/article/details/37913211

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!