在android Studio中做混淆,基本就是對Proguard-rules.pro文件的操作。混淆的過程也是有規律可循的。下面我將分幾個部分來分別介紹混淆過程。
(1)如何開啟混淆。
(2)混淆的公共部分。
(3)需要我們不混淆的代碼。
(4)libs下的第三方Jar包的混淆方式。
(5)complie的第三方Jar包的混淆方式。
(6)代碼注釋的混淆方式。
如何開啟混淆
在Android Studio中找到你的項目module的build.gradle,將minifyEnabled設置為true就ok,如下圖所示:
如何寫混淆代碼
#1.基本指令區
# 代碼混淆壓縮比,在0~7之間,默認為5,一般不做修改
-optimizationpasses 5
# 混合時不使用大小寫混合,混合后的類名為小寫
-dontusemixedcaseclassnames
# 指定不去忽略非公共庫的類
-dontskipnonpubliclibraryclasses
# 指定不去忽略非公共庫的類成員
-dontskipnonpubliclibraryclassmembers
# 不進行優化,建議使用此選項,
-dontoptimize
# 不做預校驗,preverify是proguard的四個步驟之一,Android不需要preverify 能夠加快混淆速度。
-dontpreverify
# 使我們的項目混淆后產生映射文件包含有類名->混淆后類名的映射關系
-verbose
# 使用printmapping指定映射文件的名稱
-printmapping proguardMapping.txt
# 屏蔽警告
-ignorewarnings
# 指定混淆是采用的算法,后面的參數是一個過濾器這個過濾器是谷歌推薦的算法,一般不做更改
-optimizations !code/simplification/cast,!field/*,!class/merging/*
# 保留Annotation不混淆
-keepattributes *Annotation*
# 避免混淆泛型
-keepattributes Signature
# 拋出異常時保留代碼行號
-keepattributes SourceFile,LineNumberTable
#2.默認保留區 # 保留我們使用的四大組件,自定義的Application等等這些類不被混淆 # 因為這些子類都有可能被外部調用 -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 * extends android.view.View -keep public class com.android.vending.licensing.ILicensingService -keep public class com.google.vending.licensing.ILicensingService # 保留support下的所有類及其內部類 -keep class android.support.** {*;} # 保留繼承的 -keep public class * extends android.support.v4.** -keep public class * extends android.support.v7.** -keep public class * extends android.support.annotation.** # 保留本地native方法不被混淆 -keepclasseswithmembernames class * { native <methods>; } # 保留在Activity中的方法參數是view的方法,這樣一來我們在layout中寫的onClick就不會被影響 -keepclassmembers class * extends android.app.Activity{ public void *(android.view.View); } # 保留枚舉類不被混淆 -keepclassmembers enum * { public static **[] values(); public static ** valueOf(java.lang.String); } # 保留我們自定義控件(繼承自View)不被混淆 -keep public class * extends android.view.View{ *** get*(); void set*(***); public <init>(android.content.Context); public <init>(android.content.Context, android.util.AttributeSet); public <init>(android.content.Context, android.util.AttributeSet, int); } -keepclasseswithmembers class * { public <init>(android.content.Context, android.util.AttributeSet); public <init>(android.content.Context, android.util.AttributeSet, int); } # 保留Parcelable序列化類不被混淆 -keep class * implements android.os.Parcelable { public static final android.os.Parcelable$Creator *; } # 保留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(); } # 保留R下面的資源 -keep class **.R$* { *; } # 對於帶有回調函數的onXXEvent、**On*Listener的,不能被混淆 -keepclassmembers class * { void *(**On*Event); void *(**On*Listener); } # 避免layout中onclick方法(android:onclick="onClick")混淆 -keepclassmembers class * extends android.app.Activity{ public void *(android.view.View); } # webview -keepclassmembers class fqcn.of.javascript.interface.for.webview { public *; } -keepclassmembers class * extends android.webkit.webViewClient { public void *(android.webkit.WebView, java.lang.String, android.graphics.Bitmap); public boolean *(android.webkit.WebView, java.lang.String); } -keepclassmembers class * extends android.webkit.webViewClient { public void *(android.webkit.webView, jav.lang.String); } #在app中與HTML5的JavaScript的交互進行特殊處理 #我們需要確保這些js要調用的原生方法不能夠被混淆,於是我們需要做如下處理: #-keepclassmembers class com.XXX.XXX.JSInterface { # <methods>; #}
# AndroidX混淆
-keep class com.google.android.material.** {*;}
-keep class androidx.** {*;}
-keep public class * extends androidx.**
-keep interface androidx.** {*;}
-dontwarn com.google.android.material.**
-dontnote com.google.android.material.**
-dontwarn androidx.**
# 自己項目中定義的實體類
-keep class com.XXX.bean.** { *; }
-keep class com.XXX.widget.** { *; }
-keep class com.XXX.utils.** { *; }
-keep class com.XXX.base.** { *; }
#第三方框架 # ButterKnife -keep class butterknife.** { *; } -dontwarn butterknife.internal.** -keep class **$$ViewBinder { *; } -keepclasseswithmembernames class * { @butterknife.* <fields>; } -keepclasseswithmembernames class * { @butterknife.* <methods>; } # EventBus -keepclassmembers class ** { @org.greenrobot.eventbus.Subscribe <methods>; } -keep enum org.greenrobot.eventbus.ThreadMode { *; } -keepclassmembers class * extends org.greenrobot.eventbus.util.ThrowableFailureEvent { <init>(java.lang.Throwable); } # PictureSelector -keep class com.luck.picture.lib.** { *; } -dontwarn com.yalantis.ucrop** -keep class com.yalantis.ucrop** { *; } -keep interface com.yalantis.ucrop** { *; } -dontwarn org.codehaus.mojo.animal_sniffer.* # zxing -keep class com.google.zxing.{ *;} -dontwarn com.google.zxing.** -dontwarn cn.bingoogolapple.** -keep class cn.bingoogolapple.*{ *;} # Glide -dontwarn com.bumptech.glide.** -keep class com.bumptech.glide.**{*;} -keep public class * implements com.bumptech.glide.module.GlideModule -keep public class * extends com.bumptech.glide.module.AppGlideModule -keep public enum com.bumptech.glide.load.resource.bitmap.ImageHeaderParser$** { **[] $VALUES; public *; } # Gson -dontwarn sun.misc.** -keep class com.google.gson.examples.android.model.** { <fields>; } -keep class * extends com.google.gson.TypeAdapter -keep class * implements com.google.gson.TypeAdapterFactory -keep class * implements com.google.gson.JsonSerializer -keep class * implements com.google.gson.JsonDeserializer -keepclassmembers,allowobfuscation class * { @com.google.gson.annotations.SerializedName <fields>; } # OkHttp3 -dontwarn com.squareup.okhttp3.** -keep class com.squareup.okhttp3.** { *;} -dontwarn okio.** # Retrofit -dontnote retrofit2.Platform$IOS$MainThreadExecutor -keepattributes Exceptions -dontwarn retrofit2.** -keep class retrofit2.** { *; } # RxJava RxAndroid -dontwarn sun.misc.** -keepclassmembers class rx.internal.util.unsafe.*ArrayQueue*Field* { long producerIndex; long consumerIndex; } -keepclassmembers class rx.internal.util.unsafe.BaseLinkedQueueProducerNodeRef { rx.internal.util.atomic.LinkedQueueNode producerNode; } -keepclassmembers class rx.internal.util.unsafe.BaseLinkedQueueConsumerNodeRef { rx.internal.util.atomic.LinkedQueueNode consumerNode; } -dontnote rx.internal.util.PlatformDependent # 微信支付 -dontwarn com.tencent.mm.** -dontwarn com.tencent.wxop.stat.** -keep class com.tencent.mm.** {*;} -keep class com.tencent.wxop.stat.**{*;} # 支付寶錢包 -dontwarn com.alipay.** -dontwarn HttpUtils.HttpFetcher -dontwarn com.ta.utdid2.** -dontwarn com.ut.device.** -keep class com.alipay.android.app.IAlixPay{*;} -keep class com.alipay.android.app.IAlixPay$Stub{*;} -keep class com.alipay.android.app.IRemoteServiceCallback{*;} -keep class com.alipay.android.app.IRemoteServiceCallback$Stub{*;} -keep class com.alipay.sdk.app.PayTask{ public *;} -keep class com.alipay.sdk.app.AuthTask{ public *;} -keep class com.alipay.mobilesecuritysdk.* -keep class com.ut.* # banner -dontwarn com.youth.banner.** -keep class com.youth.banner.**{*;} # loading -keep class com.wang.avi.** { *; } -keep class com.wang.avi.indicators.** { *; } # JPTabBar -keep class com.jpeng.** {*;} # SmartRefreshLayout -keep class com.scwang.** {*;} # 萬能適配器 BaseRecyclerViewAdapterHelper -keep class com.chad.library.adapter.** { *; } -keep public class * extends com.chad.library.adapter.base.BaseQuickAdapter -keep public class * extends com.chad.library.adapter.base.BaseViewHolder -keepclassmembers public class * extends com.chad.library.adapter.base.BaseViewHolder { <init>(android.view.View); } #友盟 -keep class com.umeng.**{*;} #您如果集成了U-APM產品可以加入該混淆 -keep class com.uc.**{*;} -keepclassmembers class*{ public<init>(org.json.JSONObject); } -keepclassmembers enum*{ publicstatic**[] values(); publicstatic** valueOf(java.lang.String); } # 屏幕適配 -keep class me.jessyan.autosize.** { *; } -keep interface me.jessyan.autosize.** { *; }
# 版本更新
-dontwarn com.king.app.updater.**
-keep class com.king.app.updater.**{ *;}
-keep class * extends com.king.app.updater.**{ *;}
-keep class * implements com.king.app.updater.**{ *;}
-keepattributes InnerClasses
-dontwarn com.king.app.dialog.**
-keep class com.king.app.dialog.**{ *;}
#shareSDK
-keep class cn.sharesdk.**{*;}
-keep class com.sina.**{*;}
-keep class com.mob.**{*;}
-keep class com.bytedance.**{*;}
-dontwarn cn.sharesdk.**
-dontwarn com.sina.**
-dontwarn com.mob.**
-keep class androidx.recyclerview.widget.**{*;}
-keep class androidx.viewpager2.widget.**{*;}
待更新。。。
注:一些用到了反射的類,單獨寫一下。反射代碼不能被混淆。