the*_*osh 9 android facebook-fql facebook-android-sdk
我一直在寻找在developers.facebook网站寻找一种方式来使用新的SDK和发送FQL查询,但似乎一切都已经改变和文档都在谈论各种其他的方式来请求,me或者friends,但没有具体的信息,和那些使用我的应用程序的朋友一样?
所以我写下了一个不错的FQL查询
select uid, name, pic_square, is_app_user from user where uid in (select uid2 from friend where uid1 = me())
Run Code Online (Sandbox Code Playgroud)
而现在,我所要做的就是运行它.
由于回复朋友列表的唯一请求似乎是好的Request.executeMyFriendsRequestAsync,Request.newMyFriendsRequest我认为他们是我的朋友,但两者都不允许微调FQL查询.
如何发送查询并获取朋友列表或至少一个JSONArray?
Hackbook - FQL查询教程使用旧版本的SDK,我不知道该怎么做.
更新:
我添加了这些代码行,以为它会让我创建这个查询:
public void onCreate(Bundle savedInstanceState) {
// SOME CODE
this.openSession();
}
protected void onSessionStateChange(SessionState state, Exception exception) {
if (state.isOpened()) {
Session activeSession = getSession().getActiveSession();
facebook.setAccessToken(activeSession.getAccessToken());
facebook.setAccessExpires(activeSession.getExpirationDate().getTime());
Request req = Request.newMyFriendsRequest(activeSession, new GraphUserListCallback() {
@Override
public void onCompleted(List<GraphUser> users, Response response) {
System.out.println(response.toString());
}
});
Bundle params = new Bundle();
params.putString("method", "fql.query");
params.putString("query", "select uid, name, pic_square, is_app_user " + "from user where uid in "
+ "(select uid2 from friend where uid1 = me())");
req.setParameters(params);
Request.executeBatchAsync(req);
}
}
Run Code Online (Sandbox Code Playgroud)
我这样做了,以为它会编辑请求并添加我想要的信息,但是我收到了这个错误:
10-31 09:36:31.647: E/AndroidRuntime(15986): java.lang.NullPointerException
10-31 09:36:31.647: E/AndroidRuntime(15986): at com.sample.facebook.to.db.MainActivity$1.onCompleted(MainActivity.java:62)
10-31 09:36:31.647: E/AndroidRuntime(15986): at com.facebook.Request$2.onCompleted(Request.java:269)
10-31 09:36:31.647: E/AndroidRuntime(15986): at com.facebook.Request$4.run(Request.java:1197)
10-31 09:36:31.647: E/AndroidRuntime(15986): at android.os.Handler.handleCallback(Handler.java:587)
10-31 09:36:31.647: E/AndroidRuntime(15986): at android.os.Handler.dispatchMessage(Handler.java:92)
10-31 09:36:31.647: E/AndroidRuntime(15986): at android.os.Looper.loop(Looper.java:130)
10-31 09:36:31.647: E/AndroidRuntime(15986): at android.app.ActivityThread.main(ActivityThread.java:3691)
10-31 09:36:31.647: E/AndroidRuntime(15986): at java.lang.reflect.Method.invokeNative(Native Method)
10-31 09:36:31.647: E/AndroidRuntime(15986): at java.lang.reflect.Method.invoke(Method.java:507)
10-31 09:36:31.647: E/AndroidRuntime(15986): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:907)
10-31 09:36:31.647: E/AndroidRuntime(15986): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:665)
10-31 09:36:31.647: E/AndroidRuntime(15986): at dalvik.system.NativeStart.main(Native Method)
Run Code Online (Sandbox Code Playgroud)
C A*_*thy 21
你会做这样的事情:
String fqlQuery = "select uid, name, pic_square, is_app_user from user where uid in (select uid2 from friend where uid1 = me())";
Bundle params = new Bundle();
params.putString("q", fqlQuery);
Session session = Session.getActiveSession();
Request request = new Request(session,
"/fql",
params,
HttpMethod.GET,
new Request.Callback(){
public void onCompleted(Response response) {
Log.i(TAG, "Got results: " + response.toString());
}
});
Request.executeBatchAsync(request);
Run Code Online (Sandbox Code Playgroud)
您基本上是向"/ fql"端点发出Graph API请求,并将查询传入"q"参数.
| 归档时间: |
|
| 查看次数: |
7165 次 |
| 最近记录: |