Android Studio Gradle proguard -只混淆实际的应用程序代码,而不是第三方库



因为我反编译了我的应用程序,我注意到所有的成员,类都很容易阅读和理解,所以我的目标是让那些反编译应用程序的人更难阅读代码。

我做的第一步是修改我的gradle文件:

release {
            minifyEnabled true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-myapp.txt'
        }

文件proguard-myapp.txt位于我的项目中。

我的项目使用如下:

dependencies {
    compile 'com.android.support:support-v4:24.2.1'
    compile 'com.android.support:design:24.2.1'
    compile 'com.google.code.gson:gson:2.4'
    compile 'com.android.support:appcompat-v7:24.2.1'
    compile 'com.google.android.gms:play-services-ads:9.2.1'
    compile 'com.github.lecho:hellocharts-library:1.5.8@aar'
    compile('com.crashlytics.sdk.android:crashlytics:2.6.1@aar') {
        transitive = true;
    }
}

我一直在使用proguard规则,但我测试得越多,它就越失控。

我添加了以下规则:

-dontshrink
-dontoptimize
#charts
-keep class lecho.lib.hellocharts.** { *; }
#support library
-dontwarn android.support.**
-keep class android.support.** { *; }
#ads
-keep public class com.google.android.gms.ads.** {
   public *;
}
-keep public class com.google.ads.** {
   public *;
}
#gson
# Gson uses generic type information stored in a class file when working with fields. Proguard
# removes such information by default, so configure it to keep all of it.
-keepattributes Signature
# For using GSON @Expose annotation
-keepattributes *Annotation*
# 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.** { *; }
# Prevent proguard from stripping interface information from TypeAdapterFactory,
# JsonSerializer, JsonDeserializer instances (so they can be used in @JsonAdapter)
-keep class * implements com.google.gson.TypeAdapterFactory
-keep class * implements com.google.gson.JsonSerializer
-keep class * implements com.google.gson.JsonDeserializer

#Crashlytics
-keep class com.crashlytics.** { *; }
-dontwarn com.crashlytics.**
-keep class io.fabric.sdk.** { *; }

我的问题是:

  1. 是否有可能只混淆/优化或无论它被称为什么,只有我在应用程序中实际使用的文件,我写的那些,并留下所有其他库原样?我的意思是,只重命名,优化我的类和文件,而忽略崩溃分析,admob,支持库?

2。我试过只添加规则:

-keep class !com.mypackage.**{*;}

虽然代码在反编译时看起来很好,但应用程序无法正常工作。

这似乎不是一个正确的答案,但我发现了我编译的应用程序不工作的原因。

经过多次努力找出问题,我终于把它修好了。GSON,因为它似乎在这个答案https://stackoverflow.com/a/30982197/379865需要有类保持为了正常工作。在为与Gson相关的对象保留了类之后,它工作了。

最新更新