112

ProGuard for Androidの新しいドキュメントには、プロジェクトのホームディレクトリにあるdefault.propertiesファイルに行を追加するように記載されています。しかし、このファイルを開くと、私は上部を読みました:

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

私は何かが足りないのですか?

また、Eclipseからの本番ビルドに対してのみ(つまり、完成品をエクスポートするときに)ProGuardを有効にする方法はありますか?

4

5 に答える 5

113

Android SDK (r20 以降)

project.properties で参照されている定義済みの proguard.config を確認してください

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'

            ...
  }
 }

ここで、私が更新し続けるプロガードの「デフォルト」ファイルを確認できます: https://medium.com/code-procedure-and-rants/android-my-standard-proguard-ffeceaf65521


Android SDK (r19 以前)

これを default.properties に追加できます。今のところ問題なく手動で追加しています。

次の行を追加する場合:

proguard.config=proguard.cfg

前述のように、署名済みアプリケーションをエクスポートするときにのみ ProGuard を使用します (Android ツール => 署名済みアプリケーションのエクスポート)

Android 2.3 より前の SDK でプロジェクトを開始すると、proguard.cfgファイルは作成されません (次のdefault.propertiesように 2.3>)。

自動作成を有効にするには、Android 2.3 の SDK に更新し、既存のソース (現在持っているプロジェクトのソース) を使用して新しいプロジェクトを作成するだけです。

自動的に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

于 2011-02-18T11:23:08.407 に答える
76

私は同じことを探していたので、フォローアップだけです-そして、ここでの答えは古くなっています-最近、基本のproguard構成はsdkディレクトリにあります-したがって、これをproject.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 
于 2012-07-05T19:24:58.620 に答える
10

少なくとも ADT 16 では、実際に に行を追加することができproject.properties、それは保持されます。ターゲット SDK のバージョンを変更してみると、project.propertiesそれに応じて更新されていることがわかりますが、追加された行はまだそこにあります。ですから、この警告は言葉遣いが悪いだけだと思います。などのファイル内の設定targetがプロジェクト設定で上書きされるという意味であり、その逆ではありません。

于 2012-03-22T23:26:19.113 に答える
4

ProGuard 構成の変更は、ADT バージョン 17 で行われました。ProGuard は 4.4 から 4.7 に更新され、構成ファイル参照の違いが導入されました。既存のプロジェクトは変更されず、このバージョンおよび新しい ADT バージョンに含まれる新しいルール セットがないことに注意してください。上記のligiですでに指摘されている、新しい構成の配置に関連するドキュメントは、次の場所で入手できます。

http://tools.android.com/recent/proguardimprovements「次に、構成ファイルの処理方法を変更しました。」

于 2012-10-08T13:20:46.743 に答える
3

build.propertiesで説明したように、に行を追加できますdefault.properties

于 2011-01-22T12:08:36.673 に答える