Android 启用Proguard时(尝试使用解析库登录时)NullPointerException Facebook sdk v4.5.0

Android 启用Proguard时(尝试使用解析库登录时)NullPointerException Facebook sdk v4.5.0,android,parse-platform,facebook-sdk-4.0,android-proguard,Android,Parse Platform,Facebook Sdk 4.0,Android Proguard,我正在尝试使用ParseFacebookUtils库登录Facebook,它工作正常,但当我启用Proguard文件时,我在Facebook登录活动启动时出现以下异常: Fatal Exception: java.lang.RuntimeException: Unable to start activity ComponentInfo{my.package.name/com.facebook.FacebookActivity}: java.lang.NullPointerException

我正在尝试使用ParseFacebookUtils库登录Facebook,它工作正常,但当我启用Proguard文件时,我在Facebook登录活动启动时出现以下异常:

Fatal Exception: java.lang.RuntimeException: Unable to start activity ComponentInfo{my.package.name/com.facebook.FacebookActivity}: java.lang.NullPointerException
       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2413)
       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2471)
       at android.app.ActivityThread.access$900(ActivityThread.java:175)
       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1308)
       at android.os.Handler.dispatchMessage(Handler.java:102)
       at android.os.Looper.loop(Looper.java:146)
       at android.app.ActivityThread.main(ActivityThread.java:5602)
       at java.lang.reflect.Method.invokeNative(Method.java)
       at java.lang.reflect.Method.invoke(Method.java:515)
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1283)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099)
       at dalvik.system.NativeStart.main(NativeStart.java)
Caused by java.lang.NullPointerException
       at java.lang.Enum$1.create(Enum.java:43)
       at java.lang.Enum$1.create(Enum.java:35)
       at libcore.util.BasicLruCache.get(BasicLruCache.java:54)
       at java.lang.Enum.getSharedConstants(Enum.java:209)
       at java.lang.Enum.valueOf(Enum.java:189)
       at com.facebook.login.LoginBehavior.valueOf(LoginBehavior.java:26)
       at com.facebook.login.LoginClient$Request.(LoginClient.java)
       at com.facebook.login.LoginClient$Request.(LoginClient.java)
       at com.facebook.login.LoginClient$Request$1.createFromParcel(LoginClient.java:2521)
       at android.os.Parcel.readParcelable(Parcel.java:2111)
       at android.os.Parcel.readValue(Parcel.java:2020)
       at android.os.Parcel.readArrayMapInternal(Parcel.java:2321)
       at android.os.Bundle.unparcel(Bundle.java:249)
       at android.os.Bundle.getString(Bundle.java:1118)
       at android.content.Intent.getStringExtra(Intent.java:5145)
       at com.google.android.gms.analytics.Tracker$zza.zziJ(Unknown Source:4000)
       at com.google.android.gms.analytics.GoogleAnalytics.isInitialized(Unknown Source)
       at com.google.android.gms.analytics.GoogleAnalytics$zzb.onActivityStarted(Unknown Source)
       at android.app.Application.dispatchActivityStarted(Application.java:219)
       at android.app.Activity.onStart(Activity.java:1087)
       at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:535)
       at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1177)
       at android.app.Activity.performStart(Activity.java:5461)
       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2386)
       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2471)
       at android.app.ActivityThread.access$900(ActivityThread.java:175)
       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1308)
       at android.os.Handler.dispatchMessage(Handler.java:102)
       at android.os.Looper.loop(Looper.java:146)
       at android.app.ActivityThread.main(ActivityThread.java:5602)
       at java.lang.reflect.Method.invokeNative(Method.java)
       at java.lang.reflect.Method.invoke(Method.java:515)
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1283)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099)
       at dalvik.system.NativeStart.main(NativeStart.java)
我的Proguard文件:

-keep class !android.support.v7.internal.view.menu.**,android.support.v7.** {*;}
# -keep interface android.support.v7.** { *; }
-keep public class android.support.v7.widget.** { *; }
-keep public class android.support.v7.internal.widget.** { *; }

-keep public class * extends android.support.v4.view.ActionProvider {
    public <init>(android.content.Context);
}

# Keep source file names, line numbers, and Parse class/method names for easier debugging
-keepattributes SourceFile,LineNumberTable
-keepnames class com.parse.** { *; }

# Required for Parse
-keepattributes *Annotation*
-keepattributes Signature
-dontwarn android.net.SSLCertificateSocketFactory
-dontwarn android.app.Notification
-dontwarn com.squareup.**
-dontwarn okio.**

# Required for crashlytics
-keep class com.crashlytics.** { *; }
-keep class com.crashlytics.android.**

-dontwarn android.support.v4.**

# Required for eventbus
-keepclassmembers class ** {
    @org.greenrobot.eventbus.Subscribe <methods>;
}
-keep enum org.greenrobot.eventbus.ThreadMode { *; }
-keepclassmembers class ** {
    public void onEvent*(**);
}
注意:当设置为
minifyEnabled false时,应用程序正常运行,因此我的Proguard文件有问题

我知道“Android Facebook SDK文档”:

您无需执行任何其他步骤即可将ProGuard用于 Facebook Android SDK

尝试添加

-保持类com.facebook。* -保持类com.facebook.login*


在您的proguard文件中,我刚刚添加了这一行,它正在工作:

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

您必须在文件中添加以下行,这将解决您的问题

只需添加以下行

-dontwarn com.facebook.**
-keep class com.facebook.** { *; }
-keepattributes Signature  
  • 忽略该警告,或不为该软件包发出警告com.facebook
  • 将类和内部类也保存在该包中
  • 保留属性的签名

  • 我已经添加了这个
    -keepattributes签名
    ,我没有任何警告。根据proguard文档,在应用proguard-keep class com.facebook.android.*{;}-dontwarn com.facebook.android.*如果您只使用facebook sdk,我认为我们会使用-dontwarn,如果我们有一些警告,但如果我们没有任何警告,它将是无用的。这个ans是否有助于您列出您的毕业生家属仅供参考,Parse将在今年年底(2016年)关闭,你可能想把它藏起来mind@Ujju是的,我知道,谢谢:)。
    -keep class com.facebook.** { *; }
    
    -dontwarn com.facebook.**
    -keep class com.facebook.** { *; }
    -keepattributes Signature