Android項目的代碼混淆

Android項目的代碼混淆,代碼混淆:

代碼混淆有兩種重要功能。其一,混淆代碼。其二,優化代碼。有的混淆是根據自己寫得代碼有關,需要根據異常錯誤對prguard-rules.pro文件進行修正。

在app下的build.gradle文件中添加如下代碼(minifyEnabled 表示是否混淆,默認是false,這裡要記得設置成true):

release {

// 不顯示Log

// buildConfigField “boolean”, “LOG_DEBUG”, “false”

//混淆 true ,不 false

minifyEnabledtrue

shrinkResourcesfalse//改為false 就解決瞭

//Zipalign優化

zipAlignEnabledtrue

// 移除無用的resource文件

shrinkResourcesfalse

proguardFiles getDefaultProguardFile(‘proguard-android.txt’),’proguard-rules.pro’

}

其中proguard-android.txt文件是本地sdk/tools/proguard文件夾下的默認文件;prguard-rules.pro文件就是用來編寫混淆代碼的;

ignorewarnings# 抑制警告

代碼混淆壓縮比, 在0~7之間, 默認為5, 一般不做修改

-optimizationpasses5

混合時不使用大小寫混合, 混合後的類名為小寫

-dontusemixedcaseclassnames

指定不去忽略非公共庫的類

-dontskipnonpubliclibraryclasses

這句話能夠使我們的項目混淆後產生映射文件

包含有類名->混淆後類名的映射關系

-verbose

指定不去忽略非公共庫的類

-dontskipnonpubliclibraryclassmembers

不做預校驗, preverify是proguard的四個步驟之一, Android不需要preverify, 去掉這一步能夠加快混淆速度。

-dontpreverify

保留Annotation不混淆

-keepattributes*Annotation*,InnerClasses

避免混淆泛型

-keepattributesSignature

拋出異常時保留代碼行號

-keepattributesSourceFile,LineNumberTable

指定混淆是采用的算法, 後面的參數是一個過濾器

這個過濾器是谷歌推薦的算法, 一般不做更改

-optimizations!code/simplification/cast,!field/,!class/merging/

存放在app\build\outputs\mapping\release中

-verbose

混淆前後的映射

-printmappingmapping.txt

apk 包內所有 class 的內部結構

-dumpclass_files.txt

未混淆的類和成員

-printseedsseeds.txt

列出從 apk 中刪除的代碼

-printusageunused.txt

包名不使用大小寫混合 aA Aa

-dontusemixedcaseclassnames

不混淆第三方引用的庫

-dontskipnonpubliclibraryclasses

不做預校驗

-dontpreverify

保留我們使用的四大組件, 自定義的Application等等這些類不被混淆#因為這些子類都有可能被外部調用

-keeppublic class * extends android.app.Activity

-keeppublic class * extends android.app.Appliction

-keeppublic class * extends android.app.Service

-keeppublic class * extends android.content.BroadcastReceiver

-keeppublic class * extends android.content.ContentProvider

-keeppublic class * extends android.app.backup.BackupAgentHelper

-keeppublic class * extends android.preference.Preference

-keeppublic class * extends android.view.View

-keeppublic class com.android.vending.licensing.ILicensingService

你項目中需要保存的實體和類

-keepclass com.* {;}

-keepclass cn.sharesdk.onekeyshare.* {;}

-keepclass www.zhouyan.project.bus.RxCustomerSupplier {*;}

-keepclass www.zhouyan.project.retrofit.GlobalResponse {*;}

-keepclass www.zhouyan.project.view.modle.* {;}

-keepclass com.squareup.timessquare.*{;}

保留support下的所有類及其內部類

-keepclass android.support.* {;}

保留R下面的資源

-keepclass *.R$ {*;}

保留本地native方法不被混淆

-keepclasseswithmembernamesclass * {

native ;

}

保留在Activity中的方法參數是view的方法,

這樣以來我們在layout中寫的onClick就不會被影響

-keepclassmembersclass * extends android.app.Activity{

public void *(android.view.View);

}

保留枚舉類不被混淆

-keepclassmembersenum * {

public static **[] values();

public static ** valueOf(java.lang.String);

}

保留我們自定義控件(繼承自View)不被混淆

-keeppublic class * extends android.view.View{

* get*();

void set*(*);

public (android.content.Context);

public (android.content.Context, android.util.AttributeSet);

public (android.content.Context, android.util.AttributeSet, int);

}

保留Parcelable序列化類不被混淆

-keepclass * implements android.os.Parcelable {

public static final android.os.Parcelable$Creator *;

}

保留Serializable序列化的類不被混淆

-keepclassmembersclass * 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();

}

對於帶有回調函數的onXXEvent的, 不能被混淆

-keepclassmembersclass * {

void *(**On*Event);

}

-keepclass com.* {;}

如果有引用v4包可以添加下面這行

-keeppublic class * extends android.support.v4.app.Fragment

如果引用瞭v4或者v7包,percent

-dontwarnandroid.support.v4

-dontwarnandroid.support.v7

-dontwarnandroid.support.percent

bugly

-dontwarncom.tencent.bugly.**

-keeppublic class com.tencent.bugly.*{;}

OkHttp3

-dontwarncom.squareup.okhttp3.**

-keepclass com.squareup.okhttp3.* {*;}

-keepclass okhttp3.* {*;}

-keepclass okio.* {*;}

-dontwarnsun.security.**

-keepclass sun.security.* {*;}

-dontwarnokio.**

-dontwarnokhttp3.**

Retrofit2

-dontwarnretrofit2.**

-keepclass retrofit2.* {*;}

-keepattributesSignature

-keepattributesExceptions

-dontwarnorg.robovm.**

-keepclass org.robovm.* {*;}

RxJava RxAndroid

-dontwarnrx.**

-keepclass rx.* {*;}

-dontwarnsun.misc.**

-keepclassmembersclass rx.internal.util.unsafe.ArrayQueue*Field {

long producerIndex;

long consumerIndex;

}

-keepclassmembersclass rx.internal.util.unsafe.BaseLinkedQueueProducerNodeRef {

rx.internal.util.atomic.LinkedQueueNode producerNode;

}

-keepclassmembersclass rx.internal.util.unsafe.BaseLinkedQueueConsumerNodeRef {

rx.internal.util.atomic.LinkedQueueNode consumerNode;

}

Gson

如果用用到Gson解析包的, 直接添加下面這幾行就能成功混淆, 不然會報錯。

-keepattributesSignature

-keepclass sun.misc.Unsafe {*;}

-keepclass com.google.gson.examples.android.model.* {*;}

glide

-keeppublic class * implements com.bumptech.glide.module.GlideModule

-keeppublic enum com.bumptech.glide.load.resource.bitmap.ImageHeaderParser$** {

**[] $VALUES;

public *;

}

butterknife

-keepclass butterknife.* {;}

-dontwarnbutterknife.internal.**

-keepclass *ViewBinder{;}

-keepclass *OnClick{;}

-keepclasseswithmembernamesclass * {

@butterknife.* ;

}

-keepclasseswithmembernamesclass * {

@butterknife.* ;

}

sharesdk

-keepclass cn.sharesdk.*{;}

-keepclass com.sina.*{;}

-keepclass *.R$ {*;}

-keepclass *.R{;}

-dontwarncn.sharesdk.**

-dontwarn**.R$*

EventBus3.0

-keepattributes*Annotation*

-keepclassmembersclass ** {

@org.greenrobot.eventbus.Subscribe ;

}

-keepenum org.greenrobot.eventbus.ThreadMode {*;}

Only required if you use AsyncExecutor

-keepclassmembersclass * extends org.greenrobot.eventbus.util.ThrowableFailureEvent {

(Java.lang.Throwable);

}

-keep com.igexin.**

-keepclass com.igexin.*{;}

You May Also Like