Activer ProGuard dans Eclipse pour Android

la nouvelle documentation sur ProGuard pour Android dit d'ajouter une ligne à la valeur par défaut.fichier de propriétés dans le répertoire home du projet. Cependant, en ouvrant ce fichier, je lis en haut:

# This file is automatically generated by Android Tools. 
# Do not modify this file -- YOUR CHANGES WILL BE ERASED! 

est-ce que je manque quelque chose?

aussi, y a-t-il un moyen d'activer ProGuard seulement pour une construction de production à partir D'Eclipse (c.-à-d. lors de l'exportation du produit fini)?

112
demandé sur tommybee 2011-01-19 10:14:25

5 réponses

juste un suivi parce que je cherchais la même chose-et les réponses ici sont dépassées - dernièrement la config de base proguard est ici dans le dir sdk - donc vous n'avez qu'à mettre cela dans votre projet.propriétés:

proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt

si vous voulez faire des modifications spécifiques au projet, créez un projet.txt et changer la ligne en:

proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt 
75
répondu ligi 2012-07-05 19:24:58

Android SDK (R20 ou plus)

veuillez vérifier le programme prédéfini.config référencé dans le projet.propriétés

proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt

plus d'informations: http://proguard.sourceforge.net/manual/examples.html#androidapplication

Sur Gradle:

buildTypes {
 release {
            minifyEnabled true
            shrinkResources true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'

            ...
  }
 }

ici, vous pouvez vérifier un fichier proguard "default" que je continue à mettre à jour: https://medium.com/code-procedure-and-rants/android-my-standard-proguard-ffeceaf65521


Android SDK (R19 ou inférieur)

, Vous pouvez l'ajouter à la valeur par défaut.propriété. J'ai ajouté manuellement sans problème jusqu'à présent.

si vous ajoutez la ligne:

proguard.config=proguard.cfg

comme dit il ne sera utilisé ProGuard lors de l'exportation signé application (Android Outils => Exporter de Demande Signé)

si vous démarrez le projet avec le SDK Avant Android 2.3 le fichier proguard.cfg ne sera pas créé (à côté de default.properties comme en 2.3>).

pour activer la création automatique de celui-ci, il suffit de mettre à jour vers le SDK D'Android 2.3 et de créer un nouveau projet avec des sources existantes (qui sont les sources du projet que vous avez actuellement).

Automagiquement proguard.cfg remplir sera créé.

si vous voulez encore le créer manuellement, voici ce qu'il devrait contenir:

-dontusemixedcaseclassnames
-dontskipnonpubliclibraryclasses
-dontwarn android.support.**
-verbose

-dontoptimize
-dontpreverify


-keepattributes *Annotation* 
-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 com.google.vending.licensing.ILicensingService
-keep public class com.android.vending.licensing.ILicensingService
-keep public class * extends android.support.v4.app.Fragment
-keep public class * extends android.app.Fragment

-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);
}

 -keepclassmembers public class * extends android.view.View {
  void set*(***);
  *** get*();
 }

-keepclassmembers enum * {
    public static **[] values();
    public static ** valueOf(java.lang.String);
}

-keep class * implements android.os.Parcelable {
  public static final android.os.Parcelable$Creator *;
}

-keepclassmembers class **.R$* {
  public static <fields>;
}

je pense que j'ai répondu à toutes les questions ci-dessus.

mise à JOUR :

ligne par ligne d'explication:

#Use 5 step of optimization 
#-optimizationpasses 5

#When not preverifing in a case-insensitive filing system, such as Windows. This tool will unpack your processed jars,(if using windows you should then use):
-dontusemixedcaseclassnames

#Specifies not to ignore non-public library classes. As of version 4.5, this is the default setting
-dontskipnonpubliclibraryclasses

# Optimization is turned off by default. Dex does not like code run
# through the ProGuard optimize and preverify steps (and performs some
# of these optimizations on its own).    
-dontoptimize
-dontpreverify

-dontwarn android.support.**

#Specifies to write out some more information during processing. If the program terminates with an exception, this option will print out the entire stack trace, instead of just the exception message.
-verbose

#The -optimizations option disables some arithmetic simplifications that Dalvik 1.0 and 1.5 can't handle. Note that the Dalvik VM also can't handle aggressive overloading (of static fields).
#To understand or change this check http://proguard.sourceforge.net/index.html#/manual/optimizations.html
#-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*

# Note that if you want to enable optimization, you cannot just
# include optimization flags in your own project configuration file;
# instead you will need to point to the
# "proguard-android-optimize.txt" file instead of this one from your
# project.properties file.

#To repackage classes on a single package
#-repackageclasses ''

#Uncomment if using annotations to keep them.
#-keepattributes *Annotation*

#Keep classes that are referenced on the AndroidManifest
-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.google.vending.licensing.ILicensingService
-keep public class com.android.vending.licensing.ILicensingService
#Compatibility library 
-keep public class * extends android.support.v4.app.Fragment
-keep public class * extends android.app.Fragment

#To maintain custom components names that are used on layouts XML.
#Uncomment if having any problem with the approach below
#-keep public class custom.components.package.and.name.**

# keep setters in Views so that animations can still work.
# see http://proguard.sourceforge.net/manual/examples.html#beans
 -keepclassmembers public class * extends android.view.View {
  void set*(***);
  *** get*();
}

#To remove debug logs:
-assumenosideeffects class android.util.Log {
    public static *** d(...);
    public static *** v(...);
    public static *** w(...);
}

#To avoid changing names of methods invoked on layout's onClick.
# Uncomment and add specific method names if using onClick on layouts
#-keepclassmembers class * {
# public void onClickButton(android.view.View);
#}

#Maintain java native methods 
-keepclasseswithmembernames class * {
    native <methods>;
}


#To maintain custom components names that are used on layouts XML:
-keep public class * extends android.view.View {
    public <init>(android.content.Context);
}
-keep public class * extends android.view.View {
    public <init>(android.content.Context, android.util.AttributeSet);
}
-keep public class * extends android.view.View {
    public <init>(android.content.Context, android.util.AttributeSet, int);
}

#Maintain enums
-keepclassmembers enum * {
    public static **[] values();
    public static ** valueOf(java.lang.String);
}

#To keep parcelable classes (to serialize - deserialize objects to sent through Intents)
-keep class * implements android.os.Parcelable {
  public static final android.os.Parcelable$Creator *;
}

#Keep the R
-keepclassmembers class **.R$* {
    public static <fields>;
}

###### ADDITIONAL OPTIONS NOT USED NORMALLY

#To keep callback calls. Uncomment if using any
#http://proguard.sourceforge.net/index.html#/manual/examples.html#callback
#-keep class mypackage.MyCallbackClass {
#   void myCallbackMethod(java.lang.String);
#}

#Uncomment if using Serializable 
#-keepclassmembers class * implements java.io.Serializable {
#    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();
#}

mise à jour 2:

dans l'utilisation la plus récente de L'ADT/Proguard -keepclasseswithmembers au lieu de -keepclasseswithmembernames

113
répondu neteinstein 2018-06-15 23:30:30

à partir de ADT 16 au moins, vous pouvez en effet ajouter la ligne dans project.properties , et il sera préservé. Vous pouvez essayer de changer la version SDK cible, et voir que project.properties est mis à jour en conséquence, mais la ligne ajoutée est toujours là. Donc, je pense que l'avertissement est simplement mal formulé; cela signifie que les paramètres du fichier tels que target seront écrasés avec les paramètres du projet, plutôt que l'inverse.

10
répondu usethe4ce 2012-03-22 23:26:19

les changements à la configuration de ProGuard sont apparus avec la version 17 de L'ADT. ProGuard a été mis à jour de 4.4 à 4.7 et la différence dans la référence du fichier de configuration déjà notée a été introduite. Il est à noter que les projets existants resteraient inchangés, ce qui les laisserait sans le nouvel ensemble de règles inclus dans cette version et les versions plus récentes de L'ADT. Les COD pertinents pour les configurations plus récentes, déjà notés par ligi ci-dessus, sont disponibles à: -

http://tools.android.com/recent/proguardimprovements " Deuxièmement, nous avons changé la façon dont les fichiers de configuration sont traités."

4
répondu phillxnet 2017-05-23 12:02:42

vous pouvez ajouter la ligne à build.properties , comme indiqué dans default.properties .

3
répondu Eric Lafortune 2013-07-31 12:59:29