2013-01-02 93 views
1

后不会被删除这是我proguard的-project.txt日志甚至使用ProGuard

# This is a configuration file for ProGuard. 
# http://proguard.sourceforge.net/index.html#manual/usage.html 

-dontusemixedcaseclassnames 
-dontskipnonpubliclibraryclasses 
-verbose 

# 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 
# 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. 

-keepattributes *Annotation* 

-keep public class com.myApp.mobileApp.** 
-keep public class com.myApp.mobileApp.** { 
    *; 
} 

-keep public class com.google.vending.licensing.ILicensingService{*;} 
-keep public class com.android.vending.licensing.ILicensingService{*;} 
-keep public class * extends android.app.Application{*;} 
-keep public class * extends android.app.Activity{*;} 
-keep public class * extends android.app.MapActivity{*;} 
-keep public class * extends android.app.PreferenceActivity{*;} 
-keep public class * extends android.view.View{*;} 
-keep public class * extends android.widget.BaseAdapter{*;} 
-keep public class * extends android.app.Service{*;} 
-keep public class * extends android.content.BroadcastReceiver{*;} 
-keep public class * implements android.view.View.OnTouchListener{*;} 
-keep public class * implements android.view.View.OnClickListener{*;} 
-keep public class * extends com.actionbarsherlock.app.SherlockActivity{*;} 
-keep public class * extends com.actionbarsherlock.app.SherlockFragmentActivity{*;} 
-keep public class * extends com.actionbarsherlock.app.SherlockMapActivity{*;} 
-keep public class * extends com.readystatesoftware.mapviewballoons.BalloonItemizedOverlay<OverlayItem>{*;} 
-keep public class * extends com.actionbarsherlock.app.SherlockFragment{*;} 

-keep class android.support.v4.app.** { *; } 
-keep interface android.support.v4.app.** { *; } 
-keep class com.actionbarsherlock.** { *; } 
-keep interface com.actionbarsherlock.** { *; } 

-libraryjars libs/android-support-v4.jar 
-libraryjars libs/apache-mime4j-0.6.jar 
-libraryjars libs/httpmime-4.0.1.jar 
-libraryjars libs/libGoogleAnalyticsV2.jar 

-assumenosideeffects class android.util.Log { 
    public static boolean isLoggable(java.lang.String, int); 
    public static int v(...); 
    public static int i(...); 
    public static int w(...); 
    public static int d(...); 
    public static int e(...); 
} 

# For native methods, see http://proguard.sourceforge.net/manual/examples.html#native 
-keepclasseswithmembers class * { 
    native <methods>; 
} 

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

# We want to keep methods in Activity that could be used in the XML attribute onClick 
-keepclassmembers class * extends android.app.Activity { 
    public void *(android.view.View); 
} 

# For enumeration classes, see http://proguard.sourceforge.net/manual/examples.html#enumerations 
-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>; 
} 

# The support library contains references to newer platform versions. 
# Don't warn about those in case this app is linking against an older 
# platform version. We know about them, and they are safe. 
-dontwarn android.support.** 
-dontwarn org.apache.** 

我的想法是删除所有日志即使混淆或任何其他优化不起作用。

bin文件夹的.apk文件大小为1.82MB其中的一个,我收到后Expoting是1.42MB。所以,我认为proguard完成了它的工作。但是,当我在模拟器上安装.apk文件并进行测试时,所有日志仍然存在。

我做错了什么?

PS:应用程序崩溃说:

java.lang.RuntimeException: java.lang.NoSuchMethodException: a(Activity,int) 

因此我加入ProGuard的-project.txt以下两行:

  • -keep公共类com.myApp.mobileApp。 **
  • -keep public class com.myApp.mobileApp。** {*; }

现在它可以工作,但日志仍然显示在Logcat中。

Comeplete错误日志:

01-02 13:18:54.711: E/AndroidRuntime(585): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.myApp.mobileApp/com.myApp.mobileApp.LandingActivity}: java.lang.RuntimeException: java.lang.NoSuchMethodException: a(Activity,int) 
01-02 13:18:54.711: E/AndroidRuntime(585): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647) 
01-02 13:18:54.711: E/AndroidRuntime(585): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663) 
01-02 13:18:54.711: E/AndroidRuntime(585): at android.app.ActivityThread.access$1500(ActivityThread.java:117) 
01-02 13:18:54.711: E/AndroidRuntime(585): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931) 
01-02 13:18:54.711: E/AndroidRuntime(585): at android.os.Handler.dispatchMessage(Handler.java:99) 
01-02 13:18:54.711: E/AndroidRuntime(585): at android.os.Looper.loop(Looper.java:130) 
01-02 13:18:54.711: E/AndroidRuntime(585): at android.app.ActivityThread.main(ActivityThread.java:3683) 
01-02 13:18:54.711: E/AndroidRuntime(585): at java.lang.reflect.Method.invokeNative(Native Method) 
01-02 13:18:54.711: E/AndroidRuntime(585): at java.lang.reflect.Method.invoke(Method.java:507) 
01-02 13:18:54.711: E/AndroidRuntime(585): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 
01-02 13:18:54.711: E/AndroidRuntime(585): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 
01-02 13:18:54.711: E/AndroidRuntime(585): at dalvik.system.NativeStart.main(Native Method) 
01-02 13:18:54.711: E/AndroidRuntime(585): Caused by: java.lang.RuntimeException: java.lang.NoSuchMethodException: a(Activity,int) 
01-02 13:18:54.711: E/AndroidRuntime(585): at com.actionbarsherlock.a.a(Unknown Source) 
01-02 13:18:54.711: E/AndroidRuntime(585): at com.actionbarsherlock.app.SherlockActivity.a(Unknown Source) 
01-02 13:18:54.711: E/AndroidRuntime(585): at com.actionbarsherlock.app.SherlockActivity.setContentView(Unknown Source) 
01-02 13:18:54.711: E/AndroidRuntime(585): at com.myApp.mobileApp.LandingActivity.onCreate(Unknown Source) 
01-02 13:18:54.711: E/AndroidRuntime(585): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
01-02 13:18:54.711: E/AndroidRuntime(585): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611) 
01-02 13:18:54.711: E/AndroidRuntime(585): ... 11 more 
01-02 13:18:54.711: E/AndroidRuntime(585): Caused by: java.lang.NoSuchMethodException: a(Activity,int) 
01-02 13:18:54.711: E/AndroidRuntime(585): at java.lang.Class.getMatchingConstructor(Class.java:643) 
01-02 13:18:54.711: E/AndroidRuntime(585): at java.lang.Class.getConstructor(Class.java:472) 
01-02 13:18:54.711: E/AndroidRuntime(585): ... 17 more 

谢谢

+0

给出完整的堆栈跟踪以查看方法a的调用方式 – Snicolas

+0

是的,我添加了完整的日志错误 –

回答

1

你只保留SherlockActivity类,而不是它的内部类。

-keep class android.support.v4.app.** { *; } 
-keep interface android.support.v4.app.** { *; } 
-keep class com.actionbarsherlock.** { *; } 
-keep interface com.actionbarsherlock.** { *; } 
-keepattributes *Annotation* 

https://stackoverflow.com/a/11151367/693752

+0

因此,除了这4行之外不需要与sherlock相关的任何内容?并删除我添加的2行以避免应用程序崩溃? –

+0

尝试一下,它应该工作。 – Snicolas

+0

好吧,我在努力。但为什么** apk文件缩小了我的400kb **。如果它没有模糊或删除任何日志,它应该与bin文件夹中的大小相同?因为我试图禁用proguard,然后导出,这样我得到了与bin相同的大小。任何想法它跳过了什么? –