Habilitando ProGuard no Eclipse para Android

112

A nova documentação do ProGuard para Android diz para adicionar uma linha ao arquivo default.properties no diretório inicial do projeto. No entanto, ao abrir este arquivo, li no topo:

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

Estou esquecendo de algo?

Além disso, existe uma maneira de habilitar o ProGuard apenas para uma construção de produção do Eclipse (ou seja, ao exportar o produto acabado)?

Ted Hopp
fonte
Concordo com seu ponto de que default.properties será regenerado todas as vezes. Portanto, é uma pergunta interessante
Aman Alam
Você deve aceitar a resposta de ligi, NeTeInStEiN não agüenta mais e confunde novo usuário.
Gaurav Agarwal
2
Mudei a resposta para ser atualizada.
neteinstein
A resposta de ligi ainda é mais clara do que a de neteinstein, para instalações mais recentes. Mais importante ainda, ele mostra proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt se você precisa de configurações personalizadas para um projeto específico.
Toolmaker Steve

Respostas:

76

apenas um follow-up porque eu estava procurando pela mesma coisa - e as respostas aqui estão desatualizadas - ultimamente a configuração do proguard básico está aqui no diretório sdk - então você só precisa colocar isso em seu project.properties:

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

se você quiser fazer modificações específicas do projeto, crie um proguard-project.txt e altere a linha para:

proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt 
Ligi
fonte
Olhando para o meu projeto (em r20, mas gerado em uma versão anterior), ele parece usar uma mistura dos métodos acima:
Tom
26
Ainda é bastante confuso porque o project.properties também diz # Este arquivo é gerado automaticamente pelo Android Tools. # Não modifique este arquivo - SUAS ALTERAÇÕES SERÃO APAGADAS!
Todd Painton de
12
"você só precisa colocar isso em seu project.properties". Esta linha estará lá em project.properties, mas comentada por padrão. Apenas descomente.
Braj
113

Android SDK (r20 ou superior)

Verifique o proguard.config predefinido referido em project.properties

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

Mais informações: http://proguard.sourceforge.net/manual/examples.html#androidapplication

No Gradle:

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

            ...
  }
 }

Aqui você pode verificar um arquivo proguard "padrão" que continuo atualizando: https://medium.com/code-procedure-and-rants/android-my-standard-proguard-ffeceaf65521


Android SDK (r19 ou inferior)

Você pode adicioná-lo ao default.properties. Eu tenho adicionado manualmente sem ter tido problemas até agora.

Se você adicionar a linha:

proguard.config=proguard.cfg

Como disse, ele só usará o ProGuard ao exportar aplicativo assinado (Android Tools => Export Signed Application)

Se você iniciar o projeto com o SDK antes do Android 2.3, o proguard.cfgarquivo não será criado (próximo a default.propertiescomo em 2.3>).

Para habilitar a criação automática dele, basta atualizar para o SDK do Android 2.3 e criar um novo projeto com as fontes existentes (que são as fontes do projeto que você possui atualmente).

Automagicamente, o proguard.cfgpreenchimento será criado.

Se ainda assim, você deseja criá-lo manualmente, é o que ele deve conter:

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

Acho que respondi a todas as perguntas acima.

ATUALIZAÇÃO :

Uma explicação linha por linha:

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

ATUALIZAÇÃO 2:

No ADT / Proguard mais recente, use em -keepclasseswithmembersvez de-keepclasseswithmembernames

neteinstein
fonte
1
@NeTeInStEiN Atualizei para SDK 16 (Android 4.x), adicionei a linha, proguard.config=proguard.cfgmas o arquivo proguard.cfg não está em lugar nenhum ... Apesar de fazer a exportação várias vezes, reiniciando o Eclipse, etc. Alguma ideia do porquê? e como consertar isso? Obrigado.
Bill The Ape
1
@NeTeInStEiN Não importa. Acontece que eu deveria ter criado um.
Bill The Ape
@NeTeInStEiN Quando crio um projeto, embora seu destino de compilação seja Android1.1, encontrei o arquivo proguard.cfg que é criado automaticamente.
hasanghaforian
1
@NeTeInStEiN Homem incrível ... Realmente aprecio seu tempo e esforços, Saúde !!
swiftBoy de
1
@ user31231234124 Adicionada a informação que você pediu.
neteinstein
10

Pelo menos a partir do ADT 16, você pode realmente adicionar a linha project.propertiese ela será preservada. Você pode tentar alterar a versão do SDK de destino e ver se ela project.propertiesé atualizada de acordo, mas a linha adicionada ainda está lá. Portanto, acho que o aviso está mal formulado; significa dizer que as configurações no arquivo targetserão substituídas pelas configurações do projeto, em vez de vice-versa.

usethe4ce
fonte
4

As mudanças na configuração do ProGuard surgiram com o ADT versão 17. O ProGuard foi atualizado de 4.4 para 4.7 e a diferença na referência do arquivo de configuração já foi apresentada. Observe que os projetos existentes permaneceriam inalterados, deixando-os sem o conjunto de regras mais recente incluído nesta e nas versões mais recentes do ADT. Documentos relevantes para arranjos de configuração mais recentes, já observados por ligi acima, estão disponíveis em: -

http://tools.android.com/recent/proguardimprovements "Em segundo lugar, mudamos a forma como os arquivos de configuração são tratados."

phillxnet
fonte
3

Você pode adicionar a linha a build.properties, conforme mencionado em default.properties.

Eric Lafortune
fonte
Onde está build.properties? Ou preciso criá-lo?
Ted Hopp
Ele está no diretório do projeto, próximo a default.properties (pelo menos com Android SDK r8).
Eric Lafortune
É onde estava procurando, mas não existe tal arquivo em nenhum dos meus projetos. Estou usando o plugin mais recente e acabei de criar um projeto de nível 8 para verificar isso.
Ted Hopp
4
Acontece que usar build.properties funciona apenas para construções Ant, não para construções Eclipse.
Ted Hopp
onde está build.properties em 2016 android studio buld?