一.AndroidProGuard基本用法ProGuard简介ProGuard是一个SourceForge上非常知名的开源项目。官网网址是:。Java的字节码一般是非常容易反编译的。为了很好的保护Java源代码,我们往往会对编译好的class文件进行混淆处理。ProGuard的主要作用就是混淆。当然它还能对字节码进行缩减体积、优化等,但那些对于我们来说都算是次要的功能。引用ProGuard官方的一段话来介绍就是:ProGuardisafreeJavaclassfileshrinker,optimizer,obfuscator,andpreverifier.Itdetectsandremovesunusedclasses,fields,methods,andattributes.Itoptimizesbytecodeandremovesunusedinstructions.Itrenamestheremainingclasses,fields,andmethodsusingshortmeaninglessnames.Finally,itpreverifiestheprocessedcodeforJava6orforJavaMicroEdition.AndroidEclipse开发环境与ProGuard在Android2.3以前,混淆Android代码只能手动添加proguard来实现代码混淆,非常不方便。而2.3以后,Google已经将这个工具加入到了SDK的工具集里。具体路径:SDK\tools\proguard。当创建一个新的Android工程时,在工程目录的根路径下,会出现一个proguard的配置文件proguard.cfg。也就是说,我们可以通过简单的配置,在我们的elipse工程中直接使用ProGuard混淆Android工程。具体混淆的步骤非常简单。首先,我们需要在工程描述文件default.properties中,添加一句话,启用ProGuard。如下所示:1#ThisfileisautomaticallygeneratedbyAndroidTools.2#Donotmodifythisfile--YOURCHANGESWILLBEERASED!3#4#ThisfilemustbecheckedinVersionControlSystems.5#6#TocustomizepropertiesusedbytheAntbuildsystemuse,7#build.properties,andoverridevaluestoadaptthescripttoyour8#projectstructure.9#Indicateswhetheranapkshouldbegeneratedforeachdensity.10split.density=false11#Projecttarget.12target=android-1013proguard.config=proguard.cfg14这样,Proguard就可以使用了。当我们正常通过AndroidTools导出ApplicationPackage时,Proguard就会自动启用,优化混淆你的代码。导出成功后,你可以反编译看看混淆的效果。一些类名、方法名和变量名等,都变成了一些无意义的字母或者数字。证明混淆成功!proguard.cfg配置稍微深入想一下混淆后的结果,你就会发现,如果一些提供给外部的类、方法、变量等名字被改变了,那么程序本身的功能就无法正常实现。那么Proguard如何知道哪些东西是可以改名,而哪些是不能改变的呢?这个是靠proguard.cfg文件来进行配置的。Android工程中默认自动生成的proguard.cfg已经针对Android的一般情况进行了配置,我们打开这个配置文件。内容大概如下:1-optimizationpasses52-dontusemixedcaseclassnames3-dontskipnonpubliclibraryclasses4-dontpreverify5-verbose6-optimizations!code/simplification/arithmetic,!field/*,!class/merging/*7-keeppublicclass*extendsandroid.app.Activity8-keeppublicclass*extendsandroid.app.Application9-keeppublicclass*extendsandroid.app.Service10-keeppublicclass*extendsandroid.content.BroadcastReceiver11-keeppublicclass*extendsandroid.content.ContentProvider12-keeppublicclass*extendsandroid.app.backup.BackupAgentHelper13-keeppublicclass*extendsandroid.preference.Preference14-keeppublicclasscom.android.vending.licensing.ILicensingService1516-keepclasseswithmembernamesclass*{17nativemethods;18}1920-keepclasseswithmembernamesclass*{21publicinit(android.content.Context,android.util.AttributeSet);22}2324-keepclasseswithmembernamesclass*{25publicinit(android.content.Context,android.util.AttributeSet,int);26}2728-keepclassmembersenum*{29publicstatic**[]values();30publicstatic**valueOf(java.lang.String);31}3233-keepclass*implementsandroid.os.Parcelable{34publicstaticfinalandroid.os.Parcelable$Creator*;35}36它主要保留了继承自Activity、Application、Service、BroadcastReceiver、ContentProvider、BackupAgentHelper、Preference和ILicensingService的子类。因为这些子类,都是可能被外部调用的。另外,它还保留了含有native方法的类、构造函数从xml构造的类(一般为View的子类)、枚举类型中的values和valueOf静态方法、继承Parcelable的跨进程数据类。在实际的一个工程项目中,可能Google自动生成的配置不能胜任我们的混淆工作。所以,我们往往需要自己编写一些ProGuard配置。这方面的资料在官网的Manual-Usage里有详细说明。大家可以研究一下。二.AndroidProguard详解本文转载于:简介Java代码是非常容易反编译的。为了很好的保护Java源代码,我们往往会对编译好的class文件进行混淆处理。ProGuard是一个混淆代码的开源项目。它的主要作用就是混淆,当然它还能对字节码进行缩减体积、优化等,但那些对于我们来说都算是次要的功能。官网网址是:。详解1、原理Java是一种跨平台的、解释型语言,Java源代码编译成中间”字节码”存储于class文件中。由于跨平台的需要,Java字节码中包括了很多源代码信息,如变量名、方法名,并且通过这些名称来访问变量和方法,这些符号带有许多语义信息,很容易被反编译成Java源代码。为了防止这种现象,我们可以使用Java混淆器对Java字节码进行混淆。混淆就是对发布出去的程序进行重新组织和处理,使得处理后的代码与处理前代码完成相同的功能,而混淆后的代码很难被反编译,即使反编译成功也很难得出程序的真正语义。被混淆过的程序代码,仍然遵照原来的档案格式和指令集,执行结果也与混淆前一样,只是混淆器将代码中的所有变量、函数、类的名称变为简短的英文字母代号,在缺乏相应的函数名和程序注释的况下,即使被反编译,也将难以阅读。同时混淆是不可逆的,在混淆的过程中一些不影响正常运行的信息将永久丢失,这些信息的丢失使程序变得更加难以理解。混淆器的作用不仅仅是保护代码,它也有精简编译后程序大小的作用。由于以上介绍的缩短变量和函数名以及丢失部分信息的原因,编译后jar文件体积大约能减少25%,这对当前费用较贵的无线网络传输是有一定意义的。2、语法[java]viewplaincopy1.-include{filename}从给定的文件中读取配置参数2.-basedirectory{directoryname}指定基础目录为以后相对的档案名称3.-injars{class_path}指定要处理的应用程序jar,war,ear和目录4.-outjars{class_path}指定处理完后要输出的jar,war,ear和目录的名称5.-libraryjars{classpath}指定要处理的应用程序jar,war,ear和目录所需要的程序库文件6.-dontskipnonpubliclibraryclasses指定不去忽略非公共的库类。7.-dontskipnonpubliclibraryclassmembers指定不去忽略包可见的库类的成员。8.9.保留选项10.-keep{Modifier}{class_specification}保护指定的类文件和类的成员11.-keepclassmembers{modifier}{class_specification}保护指定类的成员,如果此类受到保护他们会保护的更好12.-keepclasseswithmembers{class_specification}保护指定的类和类的成员,但条件是所有指定的类和类成员是要存在。13.-keepnames{class_specification}保护指定的类和类的成员的名称(如果他们不会压缩步骤中删除)14.-keepclassmembernames{class_specification}保护指定的类的成员的名称(如果他们不会压缩步骤中删除)15.-keepclasseswithmembernames{class_specification}保护指定的类和类的成员的名称,如果所有指定的类成员出席(在压缩步骤之后)16.-printseeds{filename}列出类和类的成员-keep选项的清单,标准输出到给定的文件17.18.压缩19.-dontshrink不压缩输入的类文件20.-printusage{filename}21.-whyareyoukeeping{class_specification}22.23.优化24.-dontoptimize不优化输入的类文件25.-assumenosideeffects{class_specification}优化时假设指定的方法,没有任何副用26.-allowaccessmodification优化时允许访问并修改有修饰符的类和类的成员27.28.混淆29.-dontobfuscate不混淆输入的类文件30.-printmapping{filename}31.-applymapping{filename}重用映射增