我創建了一個facebook集成應用程序。我可以正確登錄和註銷,而且沒有任何問題,並且當我登錄並關閉應用程序時,然後重新打開它,我可以正確註銷。但我的問題是當我登錄然後從Eclipse運行應用程序我無法註銷。它顯示錯誤。無法從Facebook會話登出
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
facebook = new Facebook(APP_ID);
mAsyncRunner = new AsyncFacebookRunner(facebook);
sharePref = getPreferences(MODE_PRIVATE);
facebook.setAccessToken(sharePref.getString(ACCESS_TOKEN, null));
facebook.setAccessExpires(sharePref.getLong(EXPIRE_SESSION, 0));
buttonLogin.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
loginToFacebook();
}
});
buttonLogout.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
logoutFacebook();
}
});
}
public void loginToFacebook() {
if (!facebook.isSessionValid()) {
facebook.authorize(this, PERMISSIONS, Facebook.FORCE_DIALOG_AUTH,
new DialogListener() {
@Override
public void onFacebookError(FacebookError e) {
}
@Override
public void onError(DialogError e) {
}
@Override
public void onComplete(Bundle values) {
SharedPreferences.Editor editor = sharePref.edit();
editor.putString(ACCESS_TOKEN,
facebook.getAccessToken());
editor.putLong(EXPIRE_SESSION,
facebook.getAccessExpires());
editor.commit();
}
@Override
public void onCancel() {
}
});
} else {
Toast.makeText(getApplicationContext(), "You Already Login",
Toast.LENGTH_SHORT).show();
}
}
protected void logoutFacebook() {
if (facebook.isSessionValid()) {
mAsyncRunner.logout(this,
new RequestListener() {
@Override
public void onComplete(String response, Object state) {
Log.d("Logout from Facebook", response);
if (Boolean.parseBoolean(response) == true) {
Log.e("Logout from Facebook", "Great");
}
}
@Override
public void onIOException(IOException e, Object state) {
}
@Override
public void onFileNotFoundException(
FileNotFoundException e, Object state) {
}
@Override
public void onMalformedURLException(
MalformedURLException e, Object state) {
}
@Override
public void onFacebookError(FacebookError e,
Object state) {
}
});
} else {
Toast.makeText(getApplicationContext(), "Login First",
Toast.LENGTH_SHORT).show();
}
}
我這種類型的錯誤:
E/AndroidRuntime(6331): FATAL EXCEPTION: Thread-264
E/AndroidRuntime(6331): java.lang.IllegalArgumentException: Invalid context argument
E/AndroidRuntime(6331): at android.webkit.CookieSyncManager.createInstance(CookieSyncManager.java:86)
E/AndroidRuntime(6331): at com.facebook.internal.Utility.clearCookiesForDomain(Utility.java:261)
E/AndroidRuntime(6331): at com.facebook.internal.Utility.clearFacebookCookies(Utility.java:285)
E/AndroidRuntime(6331): at com.facebook.Session.closeAndClearTokenInformation(Session.java:593)
E/AndroidRuntime(6331): at com.facebook.android.Facebook.logoutImpl(Facebook.java:698)
E/AndroidRuntime(6331): at com.facebook.android.AsyncFacebookRunner$1.run(AsyncFacebookRunner.java:89)
W/ActivityManager(1202): Force finishing activity com.facebook.androidhive/.AndroidFacebookConnectActivity
W/WindowManager(1202): Failure taking screenshot for (246x437) to layer 21020
W/Trace (6331): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (6239): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (6331): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (6239): Unexpected value from nativeGetEnabledTags: 0
W/Trace (6239): Unexpected value from nativeGetEnabledTags: 0
W/Trace (6239): Unexpected value from nativeGetEnabledTags: 0
W/Trace (6239): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
E/SurfaceFlinger( 786): ro.sf.lcd_density must be defined as a build property
W/Trace (6239): Unexpected value from nativeGetEnabledTags: 0
W/Trace (6239): Unexpected value from nativeGetEnabledTags: 0
W/Trace (6239): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (6239): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (6331): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (6239): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
W/Trace (1202): Unexpected value from nativeGetEnabledTags: 0
這api是dericated。 Facebook已停止支持Facebook的版本<3.0去github,並開始與新的API Facebook 3.0最後 –
@BirajZalavadia請給任何教程 – Satheesh
完整的步驟在這裏http://developers.facebook.com/docs/android/getting-started/facebook- sdk-for-android/ –