Android中使用progurad混淆代码

第一步,取消project.properties中关于progurad的注释,开启progurad,默认的配置文件会被加载进来。

proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt

第二步,保存被AndroidManifest.xml调用或者webview的类。这是因为proguard会移除没有被调用的代码。

-keepclassmembers
class fqcn.of.javascript.interface.for.webview
 {
   public *;
}
-keep
public class *
extends android.app.Activity                     
-keep
public class *
extends android.app.Application                  
-keep
public class *
extends android.app.Service                      
-keep
public class *
extends android.content.BroadcastReceiver        
-keep
public class *
extends android.content.ContentProvider          
-keep
public class *
extends android.app.backup.BackupAgentHelper     
-keep
public class *
extends android.preference.Preference 
-keep
public class *
extends org.xmlpull.v1.XmlPullParser 

第三步,第三方类库。

#第三方类库
-keep
class android.**
 {*;}
-keep
class com.j256.ormlite.**
 {*;}
-keep
class com.baoyz.swipemenulistview.**
 {*;}
-keep
class org.ksoap2.**
 {*;}

第四步,其实这一步可以代替上面所有的keep语句,彻底将误删的概率降到最低。

那就是保留所有具有公有访问权限的类和其公共成员。

-keepclasseswithmembers
class *{
    public *;
}

第五步,删除Log代码。

-assumenosideeffects
class android.util.Log
 {
    public static ***
 e(...);
    public static ***
 w(...);
    public static ***
 wtf(...);
    public static ***
 d(...);
    public static ***
 v(...);
}

第六步,忽略警告,避免打包时某些警告出现。

-ignorewarnings                     # 忽略警告,避免打包时某些警告出现

第七步,导出apk。

Android Tools->Export Signed Application Package,混淆成功代码运行正常,大功告成。

 

 

 

android progurad语法参考

-include {filename}    从给定的文件中读取配置参数 
-basedirectory {directoryname}    指定基础目录为以后相对的档案名称 
-injars {class_path}    指定要处理的应用程序jar,war,ear和目录 
-outjars {class_path}    指定处理完后要输出的jar,war,ear和目录的名称 
-libraryjars {classpath}    指定要处理的应用程序jar,war,ear和目录所需要的程序库文件 
-dontskipnonpubliclibraryclasses    指定不去忽略非公共的库类。 
-dontskipnonpubliclibraryclassmembers    指定不去忽略包可见的库类的成员。
 
保留选项 
-keep {Modifier} {class_specification}    保护指定的类文件和类的成员 
-keepclassmembers {modifier} {class_specification}    保护指定类的成员,如果此类受到保护他们会保护的更好
-keepclasseswithmembers {class_specification}    保护指定的类和类的成员,但条件是所有指定的类和类成员是要存在。 
-keepnames {class_specification}    保护指定的类和类的成员的名称(如果他们不会压缩步骤中删除) 
-keepclassmembernames {class_specification}    保护指定的类的成员的名称(如果他们不会压缩步骤中删除) 
-keepclasseswithmembernames {class_specification}    保护指定的类和类的成员的名称,如果所有指定的类成员出席(在压缩步骤之后) 
-printseeds {filename}    列出类和类的成员-keep选项的清单,标准输出到给定的文件 
 
压缩 
-dontshrink    不压缩输入的类文件 
-printusage {filename} 
-whyareyoukeeping {class_specification}     
 
优化 
-dontoptimize    不优化输入的类文件 
-assumenosideeffects {class_specification}    优化时假设指定的方法,没有任何副作用 
-allowaccessmodification    优化时允许访问并修改有修饰符的类和类的成员 
 
混淆 
-dontobfuscate    不混淆输入的类文件 
-printmapping {filename} 
-applymapping {filename}    重用映射增加混淆 
-obfuscationdictionary {filename}    使用给定文件中的关键字作为要混淆方法的名称 
-overloadaggressively    混淆时应用侵入式重载 
-useuniqueclassmembernames    确定统一的混淆类的成员名称来增加混淆 
-flattenpackagehierarchy {package_name}    重新包装所有重命名的包并放在给定的单一包中 
-repackageclass {package_name}    重新包装所有重命名的类文件中放在给定的单一包中 
-dontusemixedcaseclassnames    混淆时不会产生形形色色的类名 
-keepattributes {attribute_name,...}    保护给定的可选属性,例如LineNumberTable, LocalVariableTable, SourceFile, Deprecated, Synthetic, Signature, and 
 
InnerClasses. 
-renamesourcefileattribute {string}    设置源文件中给定的字符串常量

 

posted @ 2016-02-19 16:00  guopeng1987  阅读(730)  评论(0编辑  收藏  举报