Android および GSON 向け ProGuard 質問する

Android および GSON 向け ProGuard 質問する

Android プロジェクト用に ProGuard を設定しています。私のプロジェクトでは GSON も使用しています。

GSONとAndroidとの互換性のためにProGuard構成を研究したところ、google-gsonが提供するこの例に出会いました。https://code.google.com/p/google-gson/source/browse/trunk/examples/android-proguard-example/proguard.cfg

ProGuard 設定を以下にコピーしました:

##---------------Begin: proguard configuration common for all Android apps ----------
-optimizationpasses 5
-dontusemixedcaseclassnames
-dontskipnonpubliclibraryclasses
-dontskipnonpubliclibraryclassmembers
-dontpreverify
-verbose
-dump class_files.txt
-printseeds seeds.txt
-printusage unused.txt
-printmapping mapping.txt
-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*

-allowaccessmodification
-keepattributes *Annotation*
-renamesourcefileattribute SourceFile
-keepattributes SourceFile,LineNumberTable
-repackageclasses ''

-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
-dontnote com.android.vending.licensing.ILicensingService

# Explicitly preserve all serialization members. The Serializable interface
# is only a marker interface, so it wouldn't save them.
-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();
}

# Preserve all native method names and the names of their classes.
-keepclasseswithmembernames class * {
    native <methods>;
}

-keepclasseswithmembernames class * {
    public <init>(android.content.Context, android.util.AttributeSet);
}

-keepclasseswithmembernames class * {
    public <init>(android.content.Context, android.util.AttributeSet, int);
}

# Preserve static fields of inner classes of R classes that might be accessed
# through introspection.
-keepclassmembers class **.R$* {
  public static <fields>;
}

# Preserve the special static methods that are required in all enumeration classes.
-keepclassmembers enum * {
    public static **[] values();
    public static ** valueOf(java.lang.String);
}

-keep public class * {
    public protected *;
}

-keep class * implements android.os.Parcelable {
  public static final android.os.Parcelable$Creator *;
}
##---------------End: proguard configuration common for all Android apps ----------

##---------------Begin: proguard configuration for 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.** { *; }

##---------------End: proguard configuration for Gson  ----------

質問:

  1. このファイルは 2011 年以降更新されていないようですが、まだ使用することをお勧めしますか? Android/GSON はそれ以降かなり変更されているため、上記のどれが不要または間違っているのかわからないため、質問します。

  2. これが推奨されない場合、Android の GSON に推奨される新しい ProGuard 構成はありますか?

ベストアンサー1

そこにある設定のほとんどは、デフォルトで Android SDK にすでに含まれていると思います。

したがって、GSON 専用のセクションだけを残して、それらのほとんどを削除できます。


私は Android SDK Tools 22.6.3 とそれに同梱されている ProGuard のバージョンを使用して Eclipse で開発しています。

GSON 2.2.4で使用しているのは次のとおりです(彼らの例に従って):

##---------------Begin: proguard configuration for 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

# 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 mypersonalclass.data.model.** { *; }

注釈に関する行が必要ないことを除けば、これはあなたが持っているものとまったく同じに見えます。


自分で追加したクラスの一部がコメント アウトされていることがわかります。独自のクラスをシリアル化/デシリアル化する場合は、 への参照の代わりにここで宣言する必要がありますmypersonalclass.data.model。これは非常に重要です。なぜなら、GSON がシリアル化に使用するフィールド名またはクラス名を ProGuard が難読化しないようにするためです。

私は常にそのようなコメントをそこに残しているので、次のライブラリやアプリをどのように構成するかがわかります。

おすすめ記事