更新日期:2021年1月6號
Android打正式的release包混淆是必備的,避免APP被反編譯,使項目中隱秘的技術或信息被別人查看。
- Eclipse中混淆配置寫在proguard-android.txt文件中,并在project.properties文件中設置
proguard.config=proguard-project.txt
- Android studio則寫在proguard-rules.pro中,當然寫在proguard-android.txt中也可以。
gradle配置:
buildTypes {
release {
buildConfigField "boolean", "LOG_DEBUG", "false" //不顯示log
zipAlignEnabled true //Zipalign優化
shrinkResources true // 移除無用的resource文件
minifyEnabled true //混淆
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
經常用第三方SDK的時候會忘了順手把混淆加進來,到了打包的時候又去找,百度噼里啪啦一堆,很是麻煩,因此在這里總結一下,下次用的時候偶就可以直接CV了,哈哈。如有不對歡迎指正。
-optimizationpasses 5 # 指定代碼的壓縮級別
-dontusemixedcaseclassnames # 不使用大小寫混合
-dontskipnonpubliclibraryclasses # 不去忽略非公共的庫類
-dontoptimize # 不優化輸入的類文件
-dontpreverify # 混淆時是否做預校驗
-verbose # 混淆時是否記錄日志
-optimizations !code/simplification/arithmetic,!field/*,!class/merging/* # 混淆時所采用的算法
-keepattributes *Annotation* # 保護注解不被混淆
-keepattributes Exceptions,InnerClasses,... # 保護異常內部類不被混淆
-keepattributes SourceFile,LineNumberTable # 保留源碼和行號
-keep public class * extends android.app.Activity # 保持哪些類不被混淆
-keep public class * extends android.app.Fragment # 保持哪些類不被混淆
-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 # 保持哪些類不被混淆
-keep public class com.google.vending.licensing.ILicensingService # 保持哪些類不被混淆
-keepclasseswithmembernames class * { # 保持 native 方法不被混淆
native <methods>;
}
-keepclasseswithmembers class * { # 保持自定義控件類不被混淆
public <init>(android.content.Context, android.util.AttributeSet);
}
-keepclasseswithmembers class * {# 保持自定義控件類不被混淆
public <init>(android.content.Context, android.util.AttributeSet, int);
}
-keepclassmembers class * extends android.app.Activity { # 保持自定義控件類不被混淆
public void *(android.view.View);
}
-keepclassmembers enum * { # 保持枚舉 enum 類不被混淆
public static **[] values();
public static ** valueOf(java.lang.String);
}
-keep class * implements android.os.Parcelable {#保持Parcelable不被混淆
public static final android.os.Parcelable$Creator *;
}
# Explicitly preserve all serialization members. The Serializable interface
# is only a marker interface, so it wouldn't save them.
-keep public class * implements java.io.Serializable {*;}
-keepclassmembers class * implements java.io.Serializable {
static final long serialVersionUID;
private static final java.io.ObjectStreamField[] serialPersistentFields;
private void writeObject(java.io.ObjectOutputStream);
private void readObject(java.io.ObjectInputStream);
java.lang.Object writeReplace();
java.lang.Object readResolve();
}
-keepclassmembers class * {
public <init> (org.json.JSONObject);
}
###注意com.demo.demo是你的包名
-keep public class com.demo.demo.R$*{
public static final int *;
}
其他混淆,例如:
Gson https://github.com/google/gson/
# removes such information by default, so configure it to keep all of it.
-keepattributes Signature
# Gson specific classes
-keep class sun.misc.Unsafe { *; }
-keep class com.google.gson.stream.** { *; }
# Application classes that will be serialized/deserialized over Gson
-keep class com.google.gson.examples.android.model.** { *; }
-keep class com.google.gson.** { *;}
#這句非常重要,主要是濾掉 com.demo.demo.bean包下的所有.class文件不進行混淆編譯,com.demo.demo是你的包名
-keep class com.demo.demo.bean.** {*;}
說明:第三方的庫如果需要添加混淆一般在文檔上會說明。