只是试图让我的应用程序访问经过身份验证的 Facebook 用户的基本信息,但我的 logcat 告诉我
06-30 16:37:27.969: WARN/System.err(1559): com.facebook.android.FacebookError: 必须使用 Activity 访问 token 来查询有关当前用户的信息。
在运行代码的身份验证之后。有人能指出我正确的方向吗?我看过一篇非常相似的帖子,其中有人使用了几乎相同的代码并且有效。
谢谢
Facebook facebook = new Facebook("187212574660004");
TextView nText;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
nText = (TextView) this.findViewById(R.id.nameText);
facebook.authorize(this, new String[] {"offline_access", "user_interests", "friends_interests"},
new DialogListener() {
public void onComplete(Bundle values) {
setContentView(R.layout.homepage);
}
public void onFacebookError(FacebookError error) {}
public void onError(DialogError e) {}
public void onCancel() {}
});
JSONObject json_data = null;
try
{
JSONObject response = Util.parseJson(facebook.request("me/friends")); // Get a friend information from facebook
JSONArray jArray = response.getJSONArray("data");
json_data = jArray.getJSONObject(0);
String name = json_data.getString("name");
Log.i("friend is", name);
nText.setText(name);
}
catch (MalformedURLException e)
{
e.printStackTrace();
}
catch (JSONException e)
{
e.printStackTrace();
}
catch (IOException e)
{
e.printStackTrace();
}
catch (FacebookError e)
{
e.printStackTrace();
}
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
facebook.authorizeCallback(requestCode, resultCode, data);
}
尝试了Manno23之前描述的方法,得到了
06-30 19:27:04.338: ERROR/AndroidRuntime(349): Caused by: java.lang.NullPointerException
06-30 19:27:04.338:错误/AndroidRuntime(349):在 com.staffit.FacebookPage.getFriends(FacebookPage.java:67)
06-30 19:27:04.338:错误/AndroidRuntime(349):在 com.staffit.FacebookPage.access$0(FacebookPage.java:55)
06-30 19:27:04.338:错误/AndroidRuntime(349):在 com.staffit.FacebookPage$1.onComplete(FacebookPage.java:41)
06-30 19:27:04.338:错误/AndroidRuntime(349):在 com.facebook.android.Facebook.authorizeCallback(Facebook.java:383)
06-30 19:27:04.338:错误/AndroidRuntime(349):在 com.staffit.FacebookPage.onActivityResult(FacebookPage.java:93)
06-30 19:27:04.338:错误/AndroidRuntime(349):在 android.app.Activity.dispatchActivityResult(Activity.java:3907)
06-30 19:27:04.338:错误/AndroidRuntime(349):在 android.app.ActivityThread.deliverResults(ActivityThread.java:2492)
06-30 19:27:04.338: 错误/AndroidRuntime(349): ... 11 更多
最佳答案
这有很多错误,但我认为您首先要掌握的也是最重要的一点是对授权的调用是异步的。
这意味着 onComplete() 在未来的某个遥远的时间被调用。您的 facebook 请求发生在代码中 onComplete() 的回调定义“之后”,但是看看它是如何异步的,这些调用将在 facebook 登录的网络请求返回之前发生,这意味着您没有身份验证 token 当你提出这个要求时。
*我应该补充一点,DialogListener 是 facebook 编写的一个便利类,用作处理异步调用回调的方式。
关于java - Android Facebook Graph api 基本信息请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6542349/