一、理論知識
ProGuard 是一款免費的Java類檔案壓縮器、優化器和混淆器。它能發現并删除無用類、字段(field)、方法和屬性值(attribute)。它也能優化位元組碼 并删除無用的指令。最後,它使用簡單無意義的名字來重命名你的類名、字段名和方法名。經過以上操作的jar檔案會變得更小,并很難進行逆向工程。
二、基本使用
在Android應用程式也可以使用
ProGuard來進行混洗打包,大大的優化Apk包的大小。但是注意ProGuard對檔案路徑的名名很有講究,不支援括号,也不支援空格。在混淆過後,可以在工程目錄的proguard中的mapping.txt看到混淆後的類名,方法名,變量名和混淆前的類名,方法名,變量名。
在使用Eclipse建立一個工程,都會在工程目錄下生産配置project.properties和proguard-project.tx。
# To enable ProGuard to shrink and obfuscate your code, uncomment this (available properties: sdk.dir, user.home):
#proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt
# Project target.
target=android-10
project.properties用于配置Android工程的一些屬性,#号的話表示目前行是注釋,這裡的proguard.config就用于指定ProGuard的混淆配置檔案,并對使用release方式打包應用程式時開啟代碼混淆功能。對于是否是使用release方式打包,和AndroidManifest.xml中application的android:debuggable屬性有很多關系。如果該值為android:debuggable="true",那麼最終就是debug方式打包。最明智的方式就是在AndroidManifest.xml并不顯示的指定它,而是是打包工具在打包時來決定它最終的值。對于ant就是ant release或ant debug。而對于直接在Eclipse中使用run 或debgu來打包的話就是debug,使用export的話就是release.
proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt
這裡的話指定了混淆的基本配置檔案proguard-android.txt,和混淆的個性化配置檔案proguard-project.txt。這裡proguard-project.txt檔案用于對前面的基本的混淆配置檔案proguard-android.txt的配置進行override和添加。
------------------------------------------------------------------------------------------------------------------------------------------
下面是混淆打包第三方jar包的處理:
在project.properties裡加上 proguard.config=proguard.cfg
proguard.cfg 配置如下:
-optimizationpasses 5
-dontusemixedcaseclassnames
-dontskipnonpubliclibraryclasses
-dontpreverify
-verbose
-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*
#忽略警告 也可以用-ignorewarnings
-dontwarn
#聲明第三方jar包,不用管第三方jar包中的.so檔案(如果有)
-libraryjars libs/baidumapapi.jar
-libraryjars libs/tencent_openapi.jar
-libraryjars libs/httpmime-4.1.3.jar
-libraryjars libs/weibo.sdk.android.sso.jar
-libraryjars libs/android-support-v4.jar
-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 com.android.vending.licensing.ILicensingService
-keepclasseswithmembernames class * {
native <methods>;
}
-keepclasseswithmembers class * {
public <init>(android.content.Context, android.util.AttributeSet);
public <init>(android.content.Context, android.util.AttributeSet, int);
-keepclassmembers class * extends android.app.Activity {
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 *;
#不混淆第三方jar包中的類
-keep class com.baidu.mapapi.** {*;}
-keep class com.tencent.tauth.** {*;}
-keep class org.apache.http.entity.mime.** {*;}
-keep class android.support.v4.** {*;}
-keep class android.net.http.** {*;}
-keep class com.weibo.sdk.android.** {*;}
-keep class com.sina.sso.** {*;}
說明一下,第三方jar包中如果有.so檔案,不用去理會,引入的第三方jar檔案不要混淆,否則可能會報異常