[英]Android Facebook LoginButton onActivityResult null pointer exception
I am attempting to implement Facebook Log-in for my Android app. 我正在尝试为我的Android应用程序实现Facebook登录。 I'm posting the test code that I wrote here. 我正在发布我在这里编写的测试代码。
public class MainActivity extends Activity {
private LoginButton loginButton;
private UiLifecycleHelper uiHelper;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
loginButton = (LoginButton) findViewById(R.id.facebookLogin);
loginButton.setOnErrorListener(new ErrorHandler());
StatusCallback callback = new CallBackHandler();
loginButton.setSessionStatusCallback(callback);
UiLifecycleHelper uiHelper = new UiLifecycleHelper(this, callback);
uiHelper.onCreate(savedInstanceState);
}
private class CallBackHandler implements Session.StatusCallback {
@Override
public void call(Session session, SessionState state,
Exception exception) {
Log.d("facebook", "changing");
Log.d("facebook state", state.toString());
if (state.isOpened()) {
Log.d("facebook", "facebook connected");
}
if (state.isClosed()) {
Log.d("facebook", "facebook disconnected");
}
}
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
uiHelper.onActivityResult(requestCode, resultCode, data);
}
When I log in to Facebook using the login button, this raises some exceptions. 当我使用登录按钮登录Facebook时,这引发了一些异常。 The full stack trace is here: 完整的堆栈跟踪在这里:
11-20 04:48:34.582: E/AndroidRuntime(2164): FATAL EXCEPTION: main
11-20 04:48:34.582: E/AndroidRuntime(2164): java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=64206, result=-1, data=Intent { (has extras) }} to activity {com.example.facebooklogin/com.example.facebooklogin.MainActivity}: java.lang.NullPointerException
11-20 04:48:34.582: E/AndroidRuntime(2164): at android.app.ActivityThread.deliverResults(ActivityThread.java:3319)
11-20 04:48:34.582: E/AndroidRuntime(2164): at android.app.ActivityThread.handleSendResult(ActivityThread.java:3362)
11-20 04:48:34.582: E/AndroidRuntime(2164): at android.app.ActivityThread.access$1100(ActivityThread.java:141)
11-20 04:48:34.582: E/AndroidRuntime(2164): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1282)
11-20 04:48:34.582: E/AndroidRuntime(2164): at android.os.Handler.dispatchMessage(Handler.java:99)
11-20 04:48:34.582: E/AndroidRuntime(2164): at android.os.Looper.loop(Looper.java:137)
11-20 04:48:34.582: E/AndroidRuntime(2164): at android.app.ActivityThread.main(ActivityThread.java:5041)
11-20 04:48:34.582: E/AndroidRuntime(2164): at java.lang.reflect.Method.invokeNative(Native Method)
11-20 04:48:34.582: E/AndroidRuntime(2164): at java.lang.reflect.Method.invoke(Method.java:511)
11-20 04:48:34.582: E/AndroidRuntime(2164): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
11-20 04:48:34.582: E/AndroidRuntime(2164): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
11-20 04:48:34.582: E/AndroidRuntime(2164): at dalvik.system.NativeStart.main(Native Method)
11-20 04:48:34.582: E/AndroidRuntime(2164): Caused by: java.lang.NullPointerException
11-20 04:48:34.582: E/AndroidRuntime(2164): at com.example.facebooklogin.MainActivity.onActivityResult(MainActivity.java:59)
11-20 04:48:34.582: E/AndroidRuntime(2164): at android.app.Activity.dispatchActivityResult(Activity.java:5293)
11-20 04:48:34.582: E/AndroidRuntime(2164): at android.app.ActivityThread.deliverResults(ActivityThread.java:3315)
11-20 04:48:34.582: E/AndroidRuntime(2164): ... 11 more
Where do you think I am wrong? 您认为我哪里错了?
You have defined UiLifecycleHelper
again in onCreate
method overriding Global UiLifecycleHelper
您已经定义UiLifecycleHelper
再次onCreate
方法覆盖全球UiLifecycleHelper
Inside onCreate you just have to initialize UiLifeCyclehelper
在onCreate内,您只需要初始化UiLifeCyclehelper
uiHelper = new UiLifecycleHelper(this, callback);
Do like this 像这样
private LoginButton loginButton;
private UiLifecycleHelper uiHelper;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
loginButton = (LoginButton) findViewById(R.id.facebookLogin);
loginButton.setOnErrorListener(new ErrorHandler());
StatusCallback callback = new CallBackHandler();
loginButton.setSessionStatusCallback(callback);
uiHelper = new UiLifecycleHelper(this, callback);
uiHelper.onCreate(savedInstanceState);
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.