2012-10-08 79 views
2

後,應用程序崩潰我只是開發了我的申請,並希望釋放,但在此之前,我想刪除的日誌和其他不必要的東西。我發現最好的方法是使用Proguard。我使用命令行,因此我使用命令ant release,並且我的應用程序已成功構建,並且在/ bin目錄中生成的新apk文件是<app-name>-release.apk。我在我的設備上安裝了該apk,但在幾次屏幕崩潰後,當我嘗試重新顯示我的應用程序並移動到其他選項卡時,它在某些點墜毀。安卓:其配置爲使用progurad

不知道它爲什麼發生。所以這是我的包含文件project.properties target=android-15
proguard.config=proguard-project.txt

的,這是我proguard-project.txt

-optimizationpasses 5 
-dontusemixedcaseclassnames 
-dontskipnonpubliclibraryclasses 
-dontpreverify 
-verbose 
-optimizations !code/simplification/arithmetic,!field/*,!class/merging/* 
-libraryjars smack.jar 
-libraryjars libphonenumber-5.0v1.5.jar 
#-keep class com.** { *; } 
#-keep class org.** { *; } 

-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.android.vending.licensing.ILicensingService 

-keepclasseswithmembernames class * { 
native <methods>; 
} 

-keepclasseswithmembers class * { 
public <init>(android.content.Context, android.util.AttributeSet); 
} 

-keepclasseswithmembers class * { 
public <init>(android.content.Context, android.util.AttributeSet, int); 
} 

-keepclassmembers class * extends android.app.Activity { 
public void *(android.view.View); 
} 

-keepclassmembers enum * { 
public static **[] values(); 
public static ** valueOf(java.lang.String); 
} 

-keep class * implements android.os.Parcelable { 
public static final android.os.Parcelable$Creator *; 
} 

錯誤日誌:

10-08 07:25:18.356: E/AndroidRuntime(1733): FATAL EXCEPTION: Contact_sync_Service 
10-08 07:25:18.356: E/AndroidRuntime(1733): java.lang.NoClassDefFoundError: com.google.i18n.phonenumbers.PhoneNumberUtil 
10-08 07:25:18.356: E/AndroidRuntime(1733):  at org.sipchat.sipua.ui.ai.run(Unknown 
Source) 
10-08 07:25:18.356: E/AndroidRuntime(1733):  at java.lang.Thread.run(Thread.java:856) 
10-08 07:26:26.756: E/dalvikvm(1751): Could not find class 'org.jivesoftware.smack.filter.MessageTypeFilter', referenced from method org.sipchat.sipua.ui.ConnectionService.a 
10-08 07:26:26.786: E/dalvikvm(1751): Could not find class 'org.jivesoftware.smack.ConnectionConfiguration', referenced from method org.sipchat.sipua.ui.ConnectionService.onStartCommand 
10-08 07:26:26.806: E/dalvikvm(1751): Could not find class 'org.jivesoftware.smack.ConnectionConfiguration', referenced from method org.sipchat.sipua.ui.af.run 
10-08 07:26:26.956: E/AndroidRuntime(1751): FATAL EXCEPTION: main 
10-08 07:26:26.956: E/AndroidRuntime(1751): java.lang.NoClassDefFoundError: org.jivesoftware.smack.ConnectionConfiguration 
10-08 07:26:26.956: E/AndroidRuntime(1751):  at org.sipchat.sipua.ui.ConnectionService.onStartCommand(Unknown Source) 
10-08 07:26:26.956: E/AndroidRuntime(1751):  at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2359) 
10-08 07:26:26.956: E/AndroidRuntime(1751):  at android.app.ActivityThread.access$1900(ActivityThread.java:123) 
10-08 07:26:26.956: E/AndroidRuntime(1751):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1210) 
10-08 07:26:26.956: E/AndroidRuntime(1751):  at android.os.Handler.dispatchMessage(Handler.java:99) 
10-08 07:26:26.956: E/AndroidRuntime(1751):  at android.os.Looper.loop(Looper.java:137) 
10-08 07:26:26.956: E/AndroidRuntime(1751):  at android.app.ActivityThread.main(ActivityThread.java:4424) 
10-08 07:26:26.956: E/AndroidRuntime(1751):  at java.lang.reflect.Method.invokeNative(Native Method) 
10-08 07:26:26.956: E/AndroidRuntime(1751):  at java.lang.reflect.Method.invoke(Method.java:511) 
10-08 07:26:26.956: E/AndroidRuntime(1751):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 
10-08 07:26:26.956: E/AndroidRuntime(1751):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 
10-08 07:26:26.956: E/AndroidRuntime(1751):  at dalvik.system.NativeStart.main(Native Method) 

更新:

這是在錯誤中提到的包是jar文件,我在proguard-project.txt

已經添加了包請讓我清楚,如果我在任何地方出了問題?
感謝

+0

你能提供從logcat的崩潰細節? 「崩潰」可能是由許多不同的事情造成的。 – Martin

+0

我用來發送郵件中的' -release.apk'文件,並從那裏我安裝它在我的設備,在這種情況下,我的logcat不顯示任何輸出。在模擬器中運行,而' .apk'文件被安裝,並與它不是崩潰 – juned

+0

對不起,我可能沒有明確的:沒有什麼錯,沒有人會能夠告訴你如何修復的說明它。 「崩潰」可能意味着很多事情。如果它是一個未處理的異常,我們需要知道該異常是什麼。如果是別的,我們需要知道你的意思是「崩潰」。 – Martin

回答

1

你給Dexguard一試?正如它在proguard網站上所說的

ProGuard現在有Android的兄弟優化器和混淆器: DexGuard。它與ProGuard兼容,它爲敏感的API提供了額外的 功能,如字符串加密,類加密和隱藏訪問 。它直接針對Dalvik字節碼,並簡化了Android構建過程。

http://www.saikoa.com/dexguard

+0

哦,只要看到,作爲proguard的是它不是免費的... – dorjeduck

+0

感謝您的回覆,但我想知道我現在的'proguard-project.txt'文件的代碼有什麼問題。如果我在progurd配置中犯了錯誤,那麼我必須先修復它,然後我應該嘗試使用dexguard – juned

+0

當然 - 只是拋棄它,以防你忽視它或其他人在這個問題上磕磕絆絆 - 祝你好運得到你的具體答案 – dorjeduck