ProGuard 最全混淆规则说明

ProGuard 最全混淆规则说明,第1张

-include filename

递归引入目录的配置文件

-basedirectory directoryname

-injars class_path

指定应用程序要处理的jars包(或者wars、ears、zip、或者目录结构),它们里面的class文件会被处理并被写入到输出jars里面。它们里面的任何非class文件会被直接复制过去但是不会处理。(需要注意过滤调一些IDE自动生成的文件);

-outjarsclass_path

指定输出jars(wars、ears、zip、目录结构)的名称;由-injars 指定的被处理的jars将被写入到指定的输出jars里。如果不指定outjars将不会有class文件被写入。

-libraryjars class_path 不混淆指定的jar库(android 项目中一般不混淆引入的第三方类库)

-skipnonpubliclibraryclasses 不混淆指定jars中的非public calsses

-dontskipnonpubliclibraryclasses 不忽略指定jars中的非public calsses (默认选项)和上面的选手想对

-dontskipnonpubliclibraryclassmembers

不忽略指定类库的public类成员(变量和方法),默认情况下,ProGuard会忽略他们

-keepdirectories [ directory_filter ] 指定要保持的目录结构,默认情况下会删除所有目录以减小jar的大小。

-target version

指定java版本号。 版本号可以是1.0,1.1,1.2,1.3,1.4,1.5(或仅5),1.6(或仅6)或1.7(或仅7)中的一个。 默认情况下,类文件的版本号保持不变。 例如,您可能想要将类文件升级到Java 6,通过更改其版本号并对其进行预验证。

-forceprocessing 强制处理输入(-injars)jars。即使输出jars是最新的。通过指定的输入,输出和配置文件或者目录的时间戳判断是否最新。

-keep [, modifier,... ] class_specification

指定需要保留的类和类成员(作为公共类库,应该保留所有可公开访问的public方法)

-keepclassmembers [, modifier,... ] class_specification

指定需要保留的类成员:变量或者方法

-keepclasseswithmembers [, modifier,... ] class_specification

指定保留的类和类成员,条件是所指定的类成员都存在(既在压缩阶段没有被删除的成员,效果和keep差不多)

-keepnames class_specification

[-keep allowshrinking class_specification 的简写]

指定要保留名称的类和类成员,前提是在压缩阶段未被删除。仅用于模糊处理

-keepclassmembernames class_specification

[-keepclassmembers allowshrinking class_specification 的简写]

指定要保留名称的类成员,前提是在压缩阶段未被删除。仅用于模糊处理

-keepclasseswithmembernames class_specification

[-keepclasseswithmembers allowshrinking class_specification 的简写]

指定要保留名称的类成员,前提是在压缩阶段后所指定的类成员都存在。仅用于模糊处理

-printseeds [ filename ]

指定详尽列出由各种-keep选项匹配的类和类成员。 列表打印到标准输出或给定文件。 该列表可用于验证是否真的找到了预期的类成员,特别是如果您使用通配符。 例如,您可能想要列出所有应用程序或您保存的所有小程序。

可用在 keep、keepclassmembers、keepclasseswithmembers 命令后面

rt.jar(java/ .class,javax/ class)

input.jar(! .gif,images/ )

input.war(lib/ .jar,support/ jar .class, .gif)

-injars classes

-injars in1.jar

-injars in2.jar

-injars in3.jar

-outjars out.jar

-injars in1.jar

-injars in2.jar

-injars in3.jar

-outjars out

-injars base_in1.jar

-injars base_in2.jar

-injars base_in3.jar

-outjars base_out.jar

-injars extra_in.jar

-outjars extra_out.jar

-injars in.jar(!images/**)

-outjars out.jar

-libraryjars <java.home>/lib/rt.jar(java/ ,javax/ )

-injars in.jar

-outjars code_out.jar(**.class)

-outjars resources_out.jar

"<java.home>/lib/rt.jar" 将被解释为 "/usr/local/java/jdk/jre/lib/rt.jar."

"<user.home>" 解释为用户的Home目录

"<user.dir>"解释为当前的工作目录

java/ .class,javax/ .class //匹配java和javax目录以及其子目录下的所有.class文件

-keep class org.codehaus.jackson.* //保持org.codehaus.jackson下面的类文件,不包括其子包里面类文件

-keep class org.codehaus.jackson. //保持org.codehaus.jackson下面所有类文件,包括其子包里面类文件

! .gif,images/** 匹配images目录下面所有文件,但不包括.gif文件

-injars in.jar(!images/**) //指定输入jar包,但移除images目录下面的所有文件

"foo, bar"匹配foo文件,和所有以bar结尾的名称。

"!foobar, bar 匹配所有bar结尾名称,foobar除外。

[@annotationtype] [[!]public|final|abstract|@ ...] [!]interface|class|enum classname

[extends|implements [@annotationtype] classname]

[{

[@annotationtype] [[!]public|private|protected|static|volatile|transient ...] <fields>|

(fieldtype fieldname)

[@annotationtype] [[!]public|private|protected|static|synchronized|native|abstract|strictfp ...] <methods>|

<init>(argumenttype,...) |

classname(argumenttype,...) |

(returntype methodname(argumenttype,...))

[@annotationtype] [[!]public|private|protected|static ... ] *

...

}]

-keepclassmembernames class com.dev.demo.one.ClassOneOne {

public *

}

-keep class com.dev.demo.ClassOne {

public <init>()

}

-keep class com.dev.demo.two.ClassTwoTwo {

public <init>(int)

}

-keepclassmember class com.dev.demo.two.ClassTwoThree {

public <methods>

private <fields>

}

-keep class * extends com.dev.demo.two.ClassTwoThree {*}

-keepnames class com.dev.demo.one.ClassOne { }

-keep class com.dev.demo.two.ClassTwoTwo$ClassTwoTwoInner{*}

针对android 选择user版本进行编译的时候,会出现proguard错误,我们需要知道的事情

1.proguard是做什么的,他的作用是将java代码进行混淆的工具

2.因为proguard是混淆工具,所以android的mk文件也对其支持为两种方式:

1.指定不需要混淆的native方法与变量的proguard.flags文件如:LOCAL_PROGUARD_FLAG_FILES := proguard.flags

2.制定编译的工程,不要使用代码混淆的工具进行代码混淆如:LOCAL_PROGUARD_ENABLED := disabled

3.不设置,默认使用LOCAL_PROGUARD_ENABLED := full.即将该工程代码全部混淆

ava代码很容易被反编译,以下使用proguard来保护我们的代码

proguard选项很多,容易迷糊,现在就把我的配置写下来(实际使用中),以供参考

1.到http://proguard.sourceforge.net/下载proguard

2.准备好你的jar包,我在这里举例叫做test.jar。

3.解压proguard,执行 bin目录下的proguardgui.bat。

如图1

4.运行如图,点击左边“input/output” 菜单,如图2

5.点击右边的“add input” 加入我们要混的jar包,test.jar

点击右边的“add output” 填入我们要输出的jar包(命名随便),这里我写 test_out.jar。

注意输出的jar包,要自己手工填写。

6.添加支持库,下边的 “Library jars,wars,ears .....” 那个框框。

点击右边的“add”。

说明一下,这里最好把你的myeclipse里java project里的libraries所有Library的jar包,copy到一个目录,然后在这里加入这些jar包,myeclipse的环境支持jar包一般,如图3

7.做完以上步骤后,应该如下图4,这样就差不多了

8.点击“shrinking” ,设置成如图5。(可根据需要设置,这里只是我的配置)

9.点击“obfuscation” ,设置如图6。(可根据需要设置,这里只是我的配置)

10.点击“optimization” 设置如图7。(可根据需要设置,这里只是我的配置)

11.点击“process”,再点击“save configuration”,在d出的对话框中,输入要保存的配置文件名称(这里我的是test.pro),最后点击“保存”。如图8

至些图形化的设置部分已经完成。

12.最后,添加要保留的类与方法。

用编辑器编辑刚才保存下来的“test.pro”,用记事本什么都可以,打开后大致应该是以下的样子

-injars test.jar

-outjars test_out.jar

-libraryjars 'C:\Program Files (x86)\Java\jdk1.6.0_10\jre\lib\rt.jar'

-libraryjars lib\ant.jar

-libraryjars lib\aopalliance-1.0.jar

-libraryjars lib\commons-dbcp-1.4.jar

-libraryjars lib\commons-fileupload-1.2.1.jar

-libraryjars lib\commons-io-1.4.jar

.....设置的支持库包,略

-dontskipnonpubliclibraryclassmembers

-dontshrink

-useuniqueclassmembernames

-keeppackagenames

-keepattributes Exceptions,InnerClasses,Signature,Deprecated,SourceFile,LineNumberTable,LocalVariable*Table,*Annotation*,Synthetic,EnclosingMethod

-keepparameternames

-ignorewarnings

....我们在这里加入要保持的类和方法,写法如下,红色部分是我们加的

-keep class org.bl.soa.components.constant.* {

public <fields>

public <methods>

*** set*(***)

*** get*()

}

-keep class org.bl.hibernate.* {

public <fields>

public <methods>

*** set*(***)

*** get*()

}

.....继续加其他的要保留的类和方法,有多少写多少。我是把test.jar里的所有类都加进来。

....后面还一些自动生成的配置,不用管它们。

....略

13.写完后,保存。

重新打开progrard,执行 bin目录下的proguardgui.bat。

点击第一个选项“Proguard”,再点击“Load configuration”,选择我们刚才保存的“test.pro”进行加载。

如下图

14.开始混代码,点击右边“process”,再点击“process!”,如下图

15,在等待处理完成后,输出的“test_out.jar”,就是混过的jar包,你可以用xjad反编看下效果。

16,如果在处理过程中有问题,一般会有提示,大部分一般都是缺少关联类,如果少了相关类,在第7步的图,把缺少的支持包加进来就可以了。

附上出处链接:http://blog.csdn.net/educast/article/details/46672639


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11307114.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-15
下一篇 2023-05-15

发表评论

登录后才能评论

评论列表(0条)

保存