android混淆打包融师,可提高apk的安全性,去除沒(méi)用的資源,減小apk的體積。(PS:雖說(shuō)高手還是能反編譯)
build.gradle中android{
buildTypes {
debug {
// 顯示Log
buildConfigField "boolean", "ISOPENLOG", "true"
minifyEnabled false //
zipAlignEnabled false
shrinkResources false
signingConfig signingConfigs.debug
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
release {
minifyEnabled true
//關(guān)閉日志
buildConfigField "boolean", "ISOPENLOG", "false"
//Zipalign優(yōu)化
zipAlignEnabled true
// 移除無(wú)用的resource文件
shrinkResources true
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard- .pro'
}
}
}
Tip:如果混淆打包遇到找不到原因的問(wèn)題带膀,不妨試試將debug也混淆,并將日志開(kāi)關(guān)打開(kāi)橙垢。
/**
- 日志開(kāi)關(guān)
*/
private static boolean isOpenLog = BuildConfig.ISOPENLOG;
//這樣配置很方便垛叨,也不會(huì)在上線時(shí)忘記關(guān)閉日志開(kāi)關(guān)。
proguard-rules.pro配置文件如下:Add project specific ProGuard rules here.
By default, the flags in this file are appended to flags specified
in D:\Android\sdk/tools/proguard/proguard-android.txt
You can edit the include path and order by changing the proguardFiles
directive in build.gradle.
For more details, see
http://developer.android.com/guide/developing/tools/proguard.html
Add any project specific keep options here:
If your project uses WebView with JS, uncomment the following
and specify the fully qualified class name to the JavaScript interface
class:
-keepclassmembers class fqcn.of.javascript.interface.for.webview {
public *;
}
指定代碼的壓縮級(jí)別
-optimizationpasses 5
包明不混合大小寫
-dontusemixedcaseclassnames
不去忽略非公共的庫(kù)類
-dontskipnonpubliclibraryclasses
優(yōu)化 不優(yōu)化輸入的類文件
-dontoptimize
預(yù)校驗(yàn)
-dontpreverify
混淆時(shí)是否記錄日志
-verbose
混淆時(shí)所采用的算法
-optimizations !code/simplification/arithmetic,!field/,!class/merging/
保護(hù)注解
-keepattributes Annotation
保持哪些類不被混淆
-keep public class * extends android.app.Fragment
-keep public class * extends android.app.Fragment
-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
如果有引用v4包可以添加下面這行
-keep public class * extends android.support.v4.app.Fragment
Bean 不被混淆
-keep class com.test.api.request.{;}
-keep class com.test.api.response.{;}
-keep class com.test.model.*{;}
忽略警告
-ignorewarning
記錄生成的日志數(shù)據(jù),gradle build時(shí)在本項(xiàng)目根目錄輸出##
apk 包內(nèi)所有 class 的內(nèi)部結(jié)構(gòu)
-dump proguard/class_files.txt
未混淆的類和成員
-printseeds proguard/seeds.txt
列出從 apk 中刪除的代碼
-printusage proguard/unused.txt
混淆前后的映射
-printmapping proguard/mapping.txt
########記錄生成的日志數(shù)據(jù)柜某,gradle build時(shí) 在本項(xiàng)目根目錄輸出-end######
如果引用了v4或者v7包
-dontwarn android.support.**
混淆保護(hù)自己項(xiàng)目的部分代碼以及引用的第三方j(luò)ar包library-end####
#保持 native 方法不被混淆
-keepclasseswithmembernames class * {
native <methods>;
}
保持自定義控件類不被混淆
-keepclasseswithmembers class * {
public <init>(android.content.Context, android.util.AttributeSet);
}
保持自定義控件類不被混淆
-keepclassmembers class * extends android.app.Activity {
public void (android.view.View);
}
-keep public class * extends android.view.View {
public <init>(android.content.Context);
public <init>(android.content.Context, android.util.AttributeSet);
public <init>(android.content.Context, android.util.AttributeSet, int);
public void set(...);
}
保持 Parcelable 不被混淆
-keep class * implements android.os.Parcelable {
public static final android.os.Parcelable$Creator *;
}
保持 Serializable 不被混淆
-keepnames class * implements java.io.Serializable
保持 Serializable 不被混淆并且enum 類也不被混淆
-keepclassmembers class * implements java.io.Serializable {
static final long serialVersionUID;
private static final java.io.ObjectStreamField[] serialPersistentFields;
!static !transient <fields>;
!private <fields>;
!private <methods>;
private void writeObject(java.io.ObjectOutputStream);
private void readObject(java.io.ObjectInputStream);
java.lang.Object writeReplace();
java.lang.Object readResolve();
}
保持枚舉 enum 類不被混淆
-keepclassmembers enum * {
public static **[] values();
public static ** valueOf(java.lang.String);
}
-keepclassmembers class * {
public void *ButtonClicked(android.view.View);
}
不混淆資源類
-keepclassmembers class *.R$ {
public static <fields>;
}
避免混淆泛型 如果混淆報(bào)錯(cuò)建議關(guān)掉
-keepattributes Signature
移除Log類打印各個(gè)等級(jí)日志的代碼嗽元,打正式包的時(shí)候可以做為禁log使用,這里可以作為禁止log打印的功能使用喂击,另外的一種實(shí)現(xiàn)方案是通過(guò)BuildConfig.DEBUG的變量來(lái)控制
-assumenosideeffects class android.util.Log {
public static *** v(...);
public static *** i(...);
public static *** d(...);
public static *** w(...);
public static *** e(...);
}
#############################################################################################
######################## 以上通用 ##################################
#############################################################################################
####################### 常用第三方模塊的混淆選項(xiàng) ###################################
gson
如果用用到Gson解析包的剂癌,直接添加下面這幾行就能成功混淆,不然會(huì)報(bào)錯(cuò)惭等。
-keepattributes Signature
Gson specific classes
-keep class sun.misc.Unsafe { *; }
Application classes that will be serialized/deserialized over Gson
-keep class com.google.gson.** { ; }
-keep class com.google.gson.stream.* { *; }
mob
-keep class android.net.http.SslError
-keep class android.webkit.{;}
-keep class cn.sharesdk.{;}
-keep class com.sina.{;}
-keep class m.framework.{;}
-keep class *.R
butterknife
-keep class butterknife.** { ; }
-dontwarn butterknife.internal.*
-keep class *$$ViewBinder { ; }
-keepclasseswithmembernames class * {
@butterknife. <fields>;
}
-keepclasseswithmembernames class * {
@butterknife. <methods>;
}
百度地圖忽略混淆
-keep class com.baidu.** { ; }
-keep class vi.com.gdi.bgl.android.{;}
X 騰訊X5內(nèi)核忽略混淆
-keep class com.tencent.** { *; }
X Smack忽略混淆
-keep class org.jivesoftware.smack.*{ ; }
-keep class org.jivesoftware.smackx.{ *; }
X glide忽略混淆
-keep class com.bumptech.glide.**{ *; }
-keep class com.sinodata.elove.utils.GlideCache{ *; }
引用的其他Module可以直接在app的這個(gè)混淆文件里配置
如果使用了Gson之類的工具要使被它解析的JavaBean類即實(shí)體類不被混淆珍手。
-keep class com.matrix.app.entity.json.** { ; }
-keep class com.matrix.appsdk.network.model.* { *; }
混淆保護(hù)自己項(xiàng)目的部分代碼以及引用的第三方j(luò)ar包library#######
如果在當(dāng)前的application module或者依賴的library module中使用了第三方的庫(kù),并不需要顯式添加規(guī)則
-libraryjars xxx
添加了反而有可能在打包的時(shí)候遭遇同一個(gè)jar多次被指定的錯(cuò)誤辞做,一般只需要添加忽略警告和保持某些class不被混淆的聲明琳要。
以libaray的形式引用了開(kāi)源項(xiàng)目,如果不想混淆 keep 掉,在引入的module的build.gradle中設(shè)置minifyEnabled=false
遇到問(wèn)題開(kāi)發(fā)logcat秤茅,一步一步解決稚补,總會(huì)混淆成功的。2333框喳。