2013-04-02 3 views
26

Наконец-то я узнал, почему мое приложение аварийно завершает работу для выпуска. ProGuard действительно удалял код из моего приложения, но я помешал этому, вручную добавив классы с командой keep в proguard-android.txt (найденный в sdk).Настройки Android ProGuard для Facebook

Для Facebook я использовал:

-keep class com.facebook.android.* 
-keep class android.webkit.WebViewClient 
-keep class * extends android.webkit.WebViewClient 
-keepclassmembers class * extends android.webkit.WebViewClient { 
    <methods>; 
} 

Но я думаю, что я до сих пор что-то отсутствует. Теперь приложение отключено, но я не могу войти в Facebook и использовать Open Graph. Когда я построил режим отладки, все это прекрасно работает.

Какие у вас настройки proguard для использования Facebook и Facebook Open Graph?

EDIT

Это мои добавленные вручную команды для ProGuard:

-dontwarn android.support.** 

# ActionBarSherlock 

-keep class android.support.** { *; } 

-keep interface android.support.** { *; } 

-keep class com.actionbarsherlock.** { *; } 

-keep interface com.actionbarsherlock.** { *; } 




# Keep line numbers to alleviate debugging stack traces 

-renamesourcefileattribute SourceFile 

-keepattributes SourceFile,LineNumberTable 

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

-keep class com.facebook.android.* 
-keep class android.webkit.WebViewClient 
-keep class * extends android.webkit.WebViewClient 
-keepclassmembers class * extends android.webkit.WebViewClient { 
    <methods>; 
} 

EDIT 2 Таким образом, проблема для не войдя в том, что я использовал мой отладки хэш-ключ вместо моего релиз хеш-ключа. Изменено это в настройках моего приложения (developers.facebook.com) и выяснилось, что мое приложение, наконец, входит в систему, но сбой после входа в систему.

не знаю, если это по-прежнему является проблемой ProGuard но возвращается сообщение об ошибке:

04-02 11:47:31.815: E/AndroidRuntime(9093): FATAL EXCEPTION: main 
04-02 11:47:31.815: E/AndroidRuntime(9093): com.facebook.ab: com.facebook.b.e got an unexpected method signature: public abstract com.facebook.b.b com.facebook.b.b.a(java.lang.Class) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at com.facebook.b.f.a(SourceFile:400) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at com.facebook.b.e.b(SourceFile:546) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at com.facebook.b.e.invoke(SourceFile:470) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at $Proxy1.a(Native Method) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at com.facebook.bb.a(SourceFile:124) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at com.facebook.ar.a(SourceFile:264) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at com.facebook.as.run(SourceFile:1240) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at android.os.Handler.handleCallback(Handler.java:615) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at android.os.Handler.dispatchMessage(Handler.java:92) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at android.os.Looper.loop(Looper.java:137) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at android.app.ActivityThread.main(ActivityThread.java:4931) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at java.lang.reflect.Method.invokeNative(Native Method) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at java.lang.reflect.Method.invoke(Method.java:511) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:791) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:558) 
04-02 11:47:31.815: E/AndroidRuntime(9093):  at dalvik.system.NativeStart.main(Native Method) 
04-02 11:47:31.820: W/ActivityManager(2130): Force finishing activity com.xxxxx.xxxx/com.xxxxx.views.MainActivity 
04-02 11:47:32.360: W/ActivityManager(2130): Activity pause timeout for ActivityRecord{4289ca58 com.xxxxx.xxxxx/com.xxxxx.xxxxx.MainActivity} 

ответ

51

фиксированной:

-keep class com.facebook.** { 
    *; 
} 

вместо:

-keepattributes Signature 
-keep class com.facebook.android.* 
-keep class android.webkit.WebViewClient 
-keep class * extends android.webkit.WebViewClient 
-keepclassmembers class * extends android.webkit.WebViewClient { 
    <methods>; 
} 

Также не забудьте проверить ваш хэш-ключ в настройках вашего приложения facebook.

+5

+1, большое спасибо за то, что поделились своим решением. – Prateek

+6

Это помогло, когда [руководство пользователя Facebook] (https://developers.facebook.com/docs/android/getting-started#proguard) бесполезно. Какой ужасный кусок шутки FB docs! – Sufian

+1

Но это не будет запутывать что-либо внутри Facebook SDK. Несмотря на то, что вы не используете все функции SDK, он просто ложится в ваш код. Что плохо. –

21

В моем случае ваше решение

-keep class com.facebook.** { 
    *; 
} 

работает, но я должен был держать

-keepattributes Signature 

Для того, чтобы получить все работает.