我正在尝试在我的 android 应用程序中实现一个简单的活动,在该应用程序中要求用户通过 facebook 登录,以便检索用户的“喜欢”。所以很明显,首先我正在通过 facebook 测试一个简单的登录。我正在使用他们在“Android 版 Facebook SDK 入门”中的确切代码 - 第 6 步(https://developers.facebook.com/docs/getting-started/facebook-sdk-for-android/3.0/ ) 但由于某种原因它不起作用。当我调试代码时,我意识到以下情况:
if(session.isOpen())
即使我已经登录到 Facebook,总是返回 false 。我已经尝试了一切来修复它,但似乎没有任何效果。
有人遇到过这个问题或知道如何解决吗?
编辑:我直接在我的手机上而不是在模拟器上尝试这个测试。我不知道这是否可能是一个问题。
提前致谢!
而且我确实尝试了这个解决方案session.isOpened() 即使成功登录到 Facebook但使用 java 6 或 7 仍然给出相同的哈希键也会返回 false。
编辑2:我也尝试过同样的事情,但方法略有不同。http://sonyarouje.com/2011/09/18/facebook-hash-key-for-android-apps/我仍然遇到同样的问题。session.isOpen()方法总是返回 false。
编辑 3:这是我尝试过的最新代码。我认为logcat中没有任何错误。无论如何,我会在这里链接它以防万一我遗漏了什么。
package com.example.danandroidapp;
import java.util.Arrays;
import com.facebook.FacebookException;
import com.facebook.Request;
import com.facebook.Response;
import com.facebook.Session;
import com.facebook.SessionState;
import com.facebook.model.GraphUser;
import com.facebook.widget.LoginButton;
import com.facebook.widget.LoginButton.OnErrorListener;
import android.os.Bundle;
import android.app.Activity;
import android.util.Log;
import android.view.Menu;
import android.widget.TextView;
public class MainActivity extends Activity {
private String TAG = "MainActivity";
private TextView lblEmail;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
lblEmail = (TextView) findViewById(R.id.lblEmail);
LoginButton authButton = (LoginButton) findViewById(R.id.authButton);
authButton.setOnErrorListener(new OnErrorListener() {
@Override
public void onError(FacebookException error) {
Log.i(TAG, "Error " + error.getMessage());
}
});
authButton.setReadPermissions(Arrays.asList("basic_info", "email"));
authButton.setSessionStatusCallback(new Session.StatusCallback() {
@Override
public void call(Session session, SessionState state, Exception exception) {
if(session.isOpened()) {
Log.i(TAG, "Access Token " + session.getAccessToken());
Request.executeMeRequestAsync(session, new Request.GraphUserCallback() {
@Override
public void onCompleted(GraphUser user, Response response) {
if(user != null) {
Log.i(TAG, "User ID " + user.getId());
Log.i(TAG, "Email " + user.asMap().get("email"));
lblEmail.setText(user.asMap().get("email").toString());
}
}
});
}
}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
}
还有我的 logcat 输出:https ://www.dropbox.com/s/7qg9zbhlpikfovf/log.txt