[英]App crashes after first Facebook Login
有時(不是非常頻繁)我的Android應用程序在首次使用Facebook登錄(Facebook SDK版本3.5)登錄到Facebook后崩潰。
我得到例外:
java.lang.RuntimeException: Unable to resume activity {my.app.package/com.facebook.LoginActivity}: java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=64206, result=0, data=null} to activity {my.app.package/com.facebook.LoginActivity}: java.lang.NullPointerException
有兩個不同的根例外:
有時用:
java.lang.NullPointerException at com.facebook.AuthorizationClient.startOrContinueAuth(AuthorizationClient.java:135)
有時:
Caused by: java.lang.NullPointerException at com.facebook.AuthorizationClient.logAuthorizationMethodComplete(AuthorizationClient.java:519)
在大多數情況下,我的應用程序運行正常
什么想法可能會導致這個問題?
編輯:
我的facebook sdk conf in manifest:
<activity
android:name="com.facebook.LoginActivity"
android:label="@string/app_name"
android:theme="@android:style/Theme.Translucent.NoTitleBar" />
<meta-data
android:name="com.facebook.sdk.ApplicationId"
android:value="@string/applicationId" />
活動代碼:
public class MainActivity extends FragmentActivity {
....
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initSession(savedInstanceState);
...
}
private void initSession(Bundle savedInstanceState) {
Settings.addLoggingBehavior(LoggingBehavior.INCLUDE_ACCESS_TOKENS);
Session session = Session.getActiveSession();
if (session == null) {
if (savedInstanceState != null) {
session = Session.restoreSession(this, null, statusCallback, savedInstanceState);
}
if (session == null) {
session = new Session(this);
}
Session.setActiveSession(session);
if (session.getState().equals(SessionState.CREATED_TOKEN_LOADED)) {
session.openForRead(new Session.OpenRequest(this).setCallback(statusCallback));
}
}
}
@Override
public void onStart() {
super.onStart();
Session session = Session.getActiveSession();
if (session != null) {
session.addCallback(statusCallback);
}
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
Session session = Session.getActiveSession();
if (session != null) {
session.onActivityResult(this, requestCode, resultCode, data);
}
}
@Override
public void onStop() {
super.onStop();
Session session = Session.getActiveSession();
if (session != null) {
session.removeCallback(statusCallback);
}
}
@Override
protected void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
Session session = Session.getActiveSession();
Session.saveSession(session, outState);
}
...
}
我也在以前版本的Facebook SDK中遇到此錯誤。 我有最新的Fb android客戶端。 有幫助嗎?
我今天也遇到了同樣的問題。 似乎Facebook SDK 3.5可能與舊的Facebook客戶端(如Facebook 2.1)不兼容。 我將Facebook客戶端更新到最新版本,然后就可以了。
09-13 17:50:43.592 11372.11372 Bundle W Key com.facebook.platform.protocol.PROTOCOL_VERSION expected String but value was a java.lang.Integer. The default
value <null> was returned.
09-13 17:50:43.602 11372.11372 Bundle W Attempt to cast generated internal exception:
09-13 17:50:43.602 11372.11372 Bundle W java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String
09-13 17:50:43.602 11372.11372 Bundle W at android.os.Bundle.getString(Bundle.java:1085)
09-13 17:50:43.602 11372.11372 Bundle W at android.content.Intent.getStringExtra(Intent.java:4826)
09-13 17:50:43.602 11372.11372 Bundle W at com.facebook.AuthorizationClient$KatanaLoginDialogAuthHandler.tryAuthorize(AuthorizationClient.java:821)
09-13 17:50:43.602 11372.11372 Bundle W at com.facebook.AuthorizationClient.tryCurrentHandler(AuthorizationClient.java:272)
09-13 17:50:43.602 11372.11372 Bundle W at com.facebook.AuthorizationClient.tryNextHandler(AuthorizationClient.java:238)
09-13 17:50:43.602 11372.11372 Bundle W at com.facebook.AuthorizationClient.authorize(AuthorizationClient.java:161)
09-13 17:50:43.602 11372.11372 Bundle W at com.facebook.AuthorizationClient.startOrContinueAuth(AuthorizationClient.java:142)
09-13 17:50:43.602 11372.11372 Bundle W at com.facebook.LoginActivity.onResume(LoginActivity.java:117)
09-13 17:50:43.602 11372.11372 Bundle W at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1282)
09-13 17:50:43.602 11372.11372 Bundle W at android.app.Activity.performResume(Activity.java:5287)
09-13 17:50:43.602 11372.11372 Bundle W at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3211)
09-13 17:50:43.602 11372.11372 Bundle W at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:3266)
09-13 17:50:43.602 11372.11372 Bundle W at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2579)
09-13 17:50:43.602 11372.11372 Bundle W at android.app.ActivityThread.access$600(ActivityThread.java:162)
09-13 17:50:43.602 11372.11372 Bundle W at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1413)
09-13 17:50:43.602 11372.11372 Bundle W at android.os.Handler.dispatchMessage(Handler.java:99)
09-13 17:50:43.602 11372.11372 Bundle W at android.os.Looper.loop(Looper.java:158)
09-13 17:50:43.602 11372.11372 Bundle W at android.app.ActivityThread.main(ActivityThread.java:5789)
09-13 17:50:43.602 11372.11372 Bundle W at java.lang.reflect.Method.invokeNative(Native Method)
09-13 17:50:43.602 11372.11372 Bundle W at java.lang.reflect.Method.invoke(Method.java:525)
09-13 17:50:43.602 11372.11372 Bundle W at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1027)
09-13 17:50:43.602 11372.11372 Bundle W at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:843)
09-13 17:50:43.602 11372.11372 Bundle W at dalvik.system.NativeStart.main(Native Method)
09-13 17:50:43.803 11372.11372 AndroidRuntime E FATAL EXCEPTION: main
09-13 17:50:43.803 11372.11372 AndroidRuntime E java.lang.RuntimeException: Unable to resume activity {com.mycomp.myapp/com.facebook.LoginActivity}: java.lang.NullPointe
rException
09-13 17:50:43.803 11372.11372 AndroidRuntime E at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3228)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:3266)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2579)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:4258)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at android.app.ActivityThread.access$700(ActivityThread.java:162)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1419)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at android.os.Handler.dispatchMessage(Handler.java:99)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at android.os.Looper.loop(Looper.java:158)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at android.app.ActivityThread.main(ActivityThread.java:5789)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at java.lang.reflect.Method.invokeNative(Native Method)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at java.lang.reflect.Method.invoke(Method.java:525)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1027)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:843)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at dalvik.system.NativeStart.main(Native Method)
09-13 17:50:43.803 11372.11372 AndroidRuntime E Caused by: java.lang.NullPointerException
09-13 17:50:43.803 11372.11372 AndroidRuntime E at com.facebook.AuthorizationClient.startOrContinueAuth(AuthorizationClient.java:135)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at com.facebook.LoginActivity.onResume(LoginActivity.java:117)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1282)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at android.app.Activity.performResume(Activity.java:5287)
09-13 17:50:43.803 11372.11372 AndroidRuntime E at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3211)
09-13 17:50:43.803 11372.11372 AndroidRuntime E ... 13 more
最近,我有同樣的問題,但是,我從https://github.com/facebook/facebook-android-sdk更新facebook sdk到3.5.2版本,任何有關loggining的問題都已解決。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.