9

新しいSDKを使用してFQLクエリを送信する方法を探して、 developers.facebook Webサイトを検索してきましたが、すべてが変更されたようで、ドキュメントでは、他のあらゆる種類の要求方法について説明していますmefriends、特定の情報については説明していません。それらの友達は私のアプリを使用しているかどうか?

だから私は素敵なFQLクエリを書き留めました

select uid, name, pic_square, is_app_user from user where uid in (select uid2 from friend where uid1 = me())

そして今、私がしなければならないのはそれを実行することだけです。

友達のリストを返すのに適していると思われるリクエストは、Request.executeMyFriendsRequestAsync友達Request.newMyFriendsRequestだと思っていたので、どちらもFQLクエリの微調整を許可していません。

クエリを送信して、友達のリストまたは少なくともを取得するにはどうすればよいJSONArrayですか?

ハックブック-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);

    }
}

リクエストを編集して必要な情報を追加すると思ってこれを行いましたが、次のエラーが発生しました:

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)
4

3 に答える 3

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);

基本的に、クエリを「q」パラメータに渡して、「/fql」エンドポイントに対してGraphAPIリクエストを作成します。

于 2012-10-31T17:12:41.837 に答える
2

この方法を試してください

void a(){
         String fqlQuery = "{" +
                 "'friends':'SELECT uid2 FROM friend WHERE uid1 = me() LIMIT 25'," +
                 "'friendinfo':'SELECT uid, name, pic_square FROM user WHERE uid IN " +
                 "(SELECT uid2 FROM #friends)'," +
                 "}";
           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, "Result: " + response.toString());
                   }                  
           }); 
           Request.executeBatchAsync(request);    
    }
于 2013-04-11T15:24:38.533 に答える
1

これについて説明しているスレッドへのリンクは次のとおりです。facebookandroidSDKを使用したFQL

次の形式でGraphAPI呼び出しを発行することもできます:graph.facebook.com/fql?q=QUERY

したがって、あなたの場合、次のようになります。graph.facebook.com/fql?q=select uid、name、pic_square、is_app_user from user where uid in(select uid2 from friend from uid1 = me())

編集:この機能のサンプルは、サンプルアプリ「Hackbook」 https://github.com/facebook/facebook-android-sdk/blob/master/examples/Hackbook/src/com/facebook/android/にあるようです。 FQLQuery.java

最も注目すべきは、このコードブロック(61行目):

String query = mFQLQuery.getText().toString();
Bundle params = new Bundle();
params.putString("method", "fql.query");
params.putString("query", query);
Utility.mAsyncRunner.request(null, params, new FQLRequestListener());
于 2012-10-30T19:03:43.677 に答える