Увімкнення ProGuard у програмі Eclipse для Android


112

Нова документація на ProGuard для Android говорить про додавання рядка до файлу default.properties у домашньому каталозі проекту. Однак, відкриваючи цей файл, я прочитав вгорі:

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

Я щось пропускаю?

Крім того, чи є можливість включити ProGuard лише для збірки виробництва з Eclipse (тобто при експорті готового продукту)?


Я погоджуюся з вашою думкою, що default.properties буде відновлюватися кожного разу. Таким чином, його цікаве запитання
Аман Алам

Ви повинні прийняти відповідь ліги, NeTeInStEiN вже не тримає і плутає нового користувача.
Гаурав Агарвал

2
Я змінив відповідь, щоб бути оновленою.
neteinstein

Відповідь ліги все-таки ясніша, ніж у Neteinstein, щодо нових установок. Найголовніше, що він показує proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt , чи потрібні спеціальні налаштування для конкретного проекту.
ToolmakerSteve

Відповіді:


76

лише подальше спостереження, тому що я шукав те саме - і відповіді тут застаріли - останнім часом базовий конфігуратор proguard знаходиться тут у dd dir - тому вам потрібно лише вкласти це у свій проект.properties:

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

якщо ви хочете внести зміни, що стосуються проекту, створіть proguard-project.txt та змініть рядок на:

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

Дивлячись на мій проект (у r20, але згенерований у попередньому випуску), схоже, використовується суміш з перерахованих вище методів:
Том,

26
Все ще досить заплутано, оскільки проект.properties також говорить # Цей файл автоматично генерується за допомогою Android Tools. # Не змінюйте цей файл - ваші зміни будуть знищені!
Todd Painton

12
"Ви повинні лише помістити це у свій проект.properties". Цей рядок буде присутній у project.properties, але коментується за замовчуванням. Просто не коментуйте це.
Брей

113

Android SDK (r20 або вище)

Перевірте попередньо визначений proguard.config, який посилається на проект.properties

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

Більше інформації: http://proguard.sourceforge.net/manual/examples.html#androidapplication

На Gradle:

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

            ...
  }
 }

Тут ви можете перевірити файл "за замовчуванням" proguard, який я постійно оновлюю: https://medium.com/code-procedure-and-rants/android-my-standard-proguard-ffeceaf65521


Android SDK (r19 або новішої)

Ви можете додати його до default.properties. Я додавав вручну, не маючи проблем досі.

Якщо ви додасте рядок:

proguard.config=proguard.cfg

Як було сказано, ProGuard використовуватиме лише під час експорту підписаної програми (Інструменти Android => Експорт підписаної програми)

Якщо ви запускаєте проект із SDK до Android 2.3, proguard.cfgфайл не буде створений (поряд із default.properties2.3).

Щоб увімкнути автоматичне його створення, просто оновіть до SDK Android 2.3 та створіть новий проект із наявними джерелами (які є джерелами проекту, який у вас зараз є).

Автоматично proguard.cfgзаливка буде створена.

Якщо все-таки ви хочете створити його вручну, ось що воно повинно містити:

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

Я думаю, що я відповів на всі запитання вище.

ОНОВЛЕННЯ :

Пояснення по рядку:

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

ОНОВЛЕННЯ 2:

У останньому використанні ADT / Proguard -keepclasseswithmembersзамість-keepclasseswithmembernames


1
@NeTeInStEiN Я оновив до SDK 16 (Android 4.x), додав рядок, proguard.config=proguard.cfgале файл proguard.cfg ніде не видно ... Незважаючи на те, що робили експорт кілька разів, перезапускали Eclipse і т. Д. Будь-яка ідея чому? і як це виправити? Дякую.
Білл Мавпа

1
@NeTeInStEiN Неважливо. Виявляється, я повинен був створити сам.
Білл Мавпа

@NeTeInStEiN Коли я створюю проект, хоча його ціль збірки - Android1.1, я знайшов файл proguard.cfg, який автоматично створюється.
hasanghaforian

1
@NeTeInStEiN Дивовижна людина ... Дуже цінуй свій час та зусилля, ура!
swiftBoy

1
@ user31231234124 Додано інформацію, яку ви просили.
neteinstein

10

Щонайменше, з ADT 16, ви дійсно можете додати рядок project.properties, і він буде збережений. Ви можете спробувати змінити цільову версію SDK і побачити, що project.propertiesоновлено відповідно, але доданий рядок все ще є. Отже, я думаю, що попередження просто погано сформульовано; це означає сказати, що налаштування у файлі, такі як, targetбуде замінено налаштуваннями проекту, а не навпаки.


4

Зміни в налаштуваннях ProGuard відбулися з версією ADT 17. ProGuard було оновлено з 4,4 до 4,7, і було внесено різницю в посиланні на файл конфігурації. Зауважте, що існуючі проекти залишаться незмінними, залишаючи їх без більш нового набору правил, включеного в цю та новіші версії ADT. Відповідний документ для новішої компоновки конфігурації, який уже відзначав liga вище, доступний на:

http://tools.android.com/recent/proguardimprovements "По-друге, ми змінили спосіб обробки файлів конфігурації."


3

Ви можете додати рядок до build.properties, як згадувалося в default.properties.


Де знаходиться build.properties? Або мені це потрібно створити?
Тед Хопп

Він знаходиться в каталозі проектів поруч із default.properties (принаймні, з Android SDK r8).
Ерік Лафортун

Ось де його шукали, але такого файлу немає в жодному з моїх проектів. Я використовую останній плагін і щойно створив проект рівня 8, щоб перевірити це.
Тед Хопп

4
Виявляється, що використання build.properties працює лише для збірок Ant, а не для збірок Eclipse.
Тед Хопп

де build.properties в 2016 році андроїд-студія buld?
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.