Abilitazione di ProGuard in Eclipse per Android


112

La nuova documentazione su ProGuard per Android dice di aggiungere una riga al file default.properties nella directory home del progetto. Tuttavia, aprendo questo file, ho letto in alto:

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

Mi sto perdendo qualcosa?

Inoltre, esiste un modo per abilitare ProGuard solo per una build di produzione da Eclipse (ovvero, durante l'esportazione del prodotto finito)?


Sono d'accordo sul fatto che default.properties verrà rigenerato ogni volta. Quindi, è una domanda interessante
Aman Alam

Dovresti accettare la risposta di ligi, NeTeInStEiN non regge più e confonde il nuovo utente.
Gaurav Agarwal

2
Ho cambiato la risposta per essere aggiornata.
neteinstein

La risposta di ligi è ancora più chiara di quella di neteinstein, per le installazioni più recenti. Ancora più importante, mostra proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt se hai bisogno di impostazioni personalizzate per un progetto specifico.
ToolmakerSteve

Risposte:


76

solo un seguito perché stavo cercando la stessa cosa - e le risposte qui sono obsolete - ultimamente la configurazione di proguard di base è qui nella directory sdk - quindi devi solo metterla nel tuo project.properties:

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

se vuoi apportare modifiche specifiche al progetto, crea un proguard-project.txt e cambia la riga in:

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

Guardando il mio progetto (in r20, ma generato in una versione precedente) sembra utilizzare un mix dei metodi di cui sopra:
Tom

26
Ancora abbastanza confuso perché il project.properties dice anche # Questo file viene generato automaticamente da Android Tools. # Non modificare questo file - LE TUE MODIFICHE SARANNO CANCELLATE!
Todd Painton

12
"devi solo metterlo nel tuo project.properties". Questa riga sarà presente in project.properties ma commentata per impostazione predefinita. Basta annullare il commento.
Braj

113

Android SDK (r20 o superiore)

Controllare il proguard.config predefinito a cui si fa riferimento in project.properties

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

Maggiori informazioni: http://proguard.sourceforge.net/manual/examples.html#androidapplication

Su Gradle:

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

            ...
  }
 }

Qui puoi controllare un file "predefinito" di proguard che continuo ad aggiornare: https://medium.com/code-procedure-and-rants/android-my-standard-proguard-ffeceaf65521


Android SDK (r19 o inferiore)

Puoi aggiungerlo a default.properties. Finora ho aggiunto manualmente senza problemi.

Se aggiungi la riga:

proguard.config=proguard.cfg

Come detto, utilizzerà ProGuard solo durante l'esportazione dell'applicazione firmata (Strumenti Android => Esporta applicazione firmata)

Se avvii il progetto con l'SDK prima di Android 2.3 il proguard.cfgfile non verrà creato (accanto a default.propertiescome in 2.3>).

Per abilitarne la creazione automatica, è sufficiente aggiornare all'SDK di Android 2.3 e creare un nuovo progetto con i sorgenti esistenti (che sono i sorgenti del progetto che hai attualmente).

Automaticamente proguard.cfgverrà creato il riempimento.

Se ancora, vuoi crearlo manualmente, questo è ciò che dovrebbe contenere:

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

Penso di aver risposto a tutte le domande precedenti.

AGGIORNAMENTO :

Una spiegazione riga per riga:

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

AGGIORNAMENTO 2:

Nell'ultimo ADT / Proguard utilizzare -keepclasseswithmembersinvece di-keepclasseswithmembernames


1
@NeTeInStEiN Ho aggiornato all'SDK 16 (Android 4.x), ho aggiunto la riga proguard.config=proguard.cfgma il file proguard.cfg non si vede da nessuna parte ... Nonostante abbia esportato più volte, riavviato Eclipse, ecc. Qualche idea sul perché? e come risolverlo? Grazie.
Bill The Ape

1
@NeTeInStEiN Non importa. Si scopre che avrei dovuto crearne uno io stesso.
Bill The Ape

@NeTeInStEiN Quando creo un progetto, anche se l'obiettivo di compilazione è Android1.1, ho trovato il file proguard.cfg che viene creato automaticamente.
hasanghaforian

1
@NeTeInStEiN Incredibile uomo ... Apprezzo davvero il tuo tempo e i tuoi sforzi, Saluti !!
swiftBoy

1
@ user31231234124 Aggiunte le informazioni richieste.
neteinstein

10

Almeno a partire da ADT 16, puoi effettivamente aggiungere la riga project.propertiese verrà preservata. Puoi provare a modificare la versione dell'SDK di destinazione e vedere che project.propertiesviene aggiornata di conseguenza, ma la riga aggiunta è ancora presente. Quindi, penso che l'avvertimento sia solo mal formulato; significa dire che le impostazioni nel file come targetverranno sovrascritte con le impostazioni del progetto, piuttosto che viceversa.


4

Le modifiche alla configurazione di ProGuard sono state apportate con la versione 17 di ADT. ProGuard è stato aggiornato dalla 4.4 alla 4.7 ed è stata introdotta la differenza nel riferimento del file di configurazione già nota. Si noti che i progetti esistenti rimarrebbero invariati, lasciandoli senza il set di regole più recente incluso in questa e nelle versioni più recenti di ADT. La documentazione pertinente per la disposizione della configurazione più recente, già annotata da ligi sopra, è disponibile su: -

http://tools.android.com/recent/proguardimprovements "In secondo luogo, abbiamo cambiato il modo in cui vengono gestiti i file di configurazione."


3

Puoi aggiungere la linea a build.properties, come menzionato in default.properties.


Dov'è build.properties? O devo crearlo?
Ted Hopp

È nella directory del progetto, accanto a default.properties (almeno con Android SDK r8).
Eric Lafortune

È lì che lo stavo cercando, ma non esiste un file del genere in nessuno dei miei progetti. Sto usando l'ultimo plugin e ho appena creato un progetto di livello 8 per verificarlo.
Ted Hopp

4
Si scopre che l'utilizzo di build.properties funziona solo per le build Ant, non per le build Eclipse.
Ted Hopp

dov'è build.properties nel 2016 Android Studio Buld?
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.