Android--混淆常用

-keep class com.badlogic.gdx.backends.android.**{ *;}
像這樣的只是不混淆:這個包下的類(不包括子包裏的東西),用到一個第三文的類就要把這個類所在的包,像上面加上

還要注意的是android-support-v4.jar這個包問題,這裏加上了對這個jar包的處理

第三方jar的混淆,

-optimizationpasses 5
-dontusemixedcaseclassnames 
-dontskipnonpubliclibraryclasses 
-dontpreverify 
-verbose 
-optimizations !code/simplification/arithmetic,!field/*,!class/merging/* 

-keep public class * extends android.app.Activity                          // 繼承activity,application,service,broadcastReceiver,contentprovider....不進行混淆
-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 com.android.vending.licensing.ILicensingService

                                                                                                                      // 這裏處理第三方的jar包,第三方JAR包處理開始
-libraryjars /libs/android-support-v4.jar
-libraryjars /libs/gdx-backend-android.jar
-libraryjars /libs/gdx.jar

                                                                                                                        // 這裏不對第三方的jar包的提出WARN    
-dontwarn com.badlogic.**
-dontwarn android.support.v4.**
-dontwarn android.support.v4.view.**

                                                                                                                        // 這裏對第三方jar包的類不進行混淆
-keep class com.badlogic.gdx.backends.android.**{ *;}
-keep class com.badlogic.gdx.**{ *;}
-keep class com.badlogic.gdx.graphics.g2d.**{ *;}
-keep class com.badlogic.gdx.graphics.**{ *;}
-keep class android.support.v4.view.**{ *;}

                                                                                                                            // 這裏第三方JAR包處理結束

-keepclasseswithmembernames class * {                                                           // natvie 方法不混淆
    native ; 

-keepclasseswithmembers class * {                                                                    // 對於所有類,有這個構造函數不進行混淆,主要是爲了在layout中的,自定義的view
    public (android.content.Context, android.util.AttributeSet); 

-keepclasseswithmembers class * { 
    public (android.content.Context, android.util.AttributeSet, int); 

-keepclassmembers class * extends android.app.Activity {                                   // 這個主要是在layout 中寫的onclick方法android:οnclick="onClick",不進行混淆
   public void *(android.view.View); 

-keepclassmembers enum * { 
    public static **[] values(); 
    public static ** valueOf(java.lang.String); 

-keep class * implements android.os.Parcelable { 
  public static final android.os.Parcelable$Creator *; 
}

 

 

1-----------------------------------------------引用--------------------------------------------------------

如果工程引入了Android-support-v4的jar類庫,那麼在工程打包混淆時,就會出現報錯提示。例如提示你:You may need to specify additional library jars (using '-libraryjars')。
 
這裏先給出解決方案,稍後我們再來解釋如何處理類似情況:
 
在proguard.cfg裏的後面,添加如下內容:
 1.-libraryjars /android-support-v4.jar 
 2.-dontwarn android.support.v4.** 
 3.-keep class android.support.v4.** { *; } 
 4.-keep public class * extends android.support.v4.** 
 5.-keep public class * extends android.app.Fragment 
 
然後你再打包看看,應該可以正常生成apk安裝包了。
 
打包出錯:
情況一:
 "類1 can't find referenced class 類2" 字面上的意思就是類1找不到類2的引用;它會建議你:"You may need to specify additional library jars (using '-libraryjars').";
需要使用-libraryjars加上項目中使用到的第三方庫就OK了。
例如:-libraryjars /android-support-v4.jar
注意:這裏引用方式是當前工程的根目錄(也可以配置其他目錄),也就是說,你要把第三方jar放到當前目錄下,否則就會警告說找不到jar文件!
 
情況二:
例如: can't find superclass or interface android.os.Parcelable$ClassLoaderCreator,碰到這樣的情況,可以使用-dontwarn com.xx.yy.**,不對錯誤提出警告。
注意:使用這個方式的話,要確保自己沒有用到這個庫裏面的類!否則就會拋ClassNotFoundException!
 
情況三:
在工程中確實用到了該類,採用上面方式還是不行。這個時候就要再增加一項:-keep class com.xx.yy.** { *;},讓當前類不混淆。
 
小結:
對於引用第三方包的情況,可以採用下面方式避免打包出錯:
-libraryjars /aaa.jar
-dontwarn com.xx.yy.**
-keep class com.xx.yy.** { *;}
 
最後打包成功,還要在機子上跑跑,看看有沒有問題。

本篇文章來源於 Linux公社網站(www.linuxidc.com)  原文鏈接:http://www.linuxidc.com/Linux/2012-07/66798.htm

-----------------------------------------------------------------------------------2--------------------------------------------------------------------

proguard.cfg配置
 
稍微深入想一下混淆後的結果,你就會發現,如果一些提供給外部的類、方法、變量等名字被改變了,那麼程序本身的功能就無法正常實現。那麼Proguard如何知道哪些東西是可以改名,而哪些是不能改變的呢?
 
這個是靠proguard.cfg文件來進行配置的。Android工程中默認自動生成的proguard.cfg已經針對Android的一般情況進行了配置,我們打開這個配置文件。內容大概如下:
 1.-optimizationpasses 5 
2.-dontusemixedcaseclassnames 
3.-dontskipnonpubliclibraryclasses 
4.-dontpreverify 
5.-verbose 
6.-optimizations !code/simplification/arithmetic,!field/*,!class/merging/* 
7. 
8.-keep public class * extends android.app.Activity 
9.-keep public class * extends android.app.Application 
10.-keep public class * extends android.app.Service 
11.-keep public class * extends android.content.BroadcastReceiver 
12.-keep public class * extends android.content.ContentProvider 
13.-keep public class * extends android.app.backup.BackupAgentHelper 
14.-keep public class * extends android.preference.Preference 
15.-keep public class com.android.vending.licensing.ILicensingService 
16. 
17.-keepclasseswithmembernames class * { 
18.    native ; 
19.} 
20. 
21.-keepclasseswithmembers class * { 
22.    public (android.content.Context, android.util.AttributeSet); 
23.} 
24. 
25.-keepclasseswithmembers class * { 
26.    public (android.content.Context, android.util.AttributeSet, int); 
27.} 
28. 
29.-keepclassmembers class * extends android.app.Activity { 
30.   public void *(android.view.View); 
31.} 
32. 
33.-keepclassmembers enum * { 
34.    public static **[] values(); 
35.    public static ** valueOf(java.lang.String); 
36.} 
37. 
38.-keep class * implements android.os.Parcelable { 
39.  public static final android.os.Parcelable$Creator *; 
40.} 
 
它主要保留了繼承自Activity、Application、Service、BroadcastReceiver、ContentProvider、 BackupAgentHelper、Preference和ILicensingService的子類。因爲這些子類,都是可能被外部調用的。
 
另外,它還保留了含有native方法的類、構造函數從xml構造的類(一般爲View的子類)、枚舉類型中的values和valueOf靜態方法、繼承Parcelable的跨進程數據類。
 
在實際的一個工程項目中,可能Google自動生成的配置不能勝任我們的混淆工作。所以,我們往往需要自己編寫一些ProGuard配置。這方面的資料在官網的Manual -> Usage裏有詳細說明,大家可以研究一下。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章