0

JavaScript を使用して非常に基本的な FQL クエリを実行すると、エラー オブジェクトが返され続けます{error_code: "2", error_msg: "Service temporarily unavailable", request_args: Array[8]}

comment_info.XID私の目的は、Facebook を介して私のウェブサイトに投稿された最近のコメントを読むことです(すべてのウェブサイト、特定の投稿に限定されません)。

これは、主に StackOverflow に投稿されたいくつかのサンプルに基づいた私のコードです。

<div id="fb-root"></div>
<div id="fbcomments"></div>
<script type="text/javascript">

window.fbAsyncInit = function() {
    var fb_app_id = '*';

    FB.init({
        appId    : fb_app_id,
        session : null, // don't refetch the session when PHP already has it
        status  : true, // check login status
        cookie  : true, // enable cookies to allow the server to access the session
        xfbml    : true // parse XFBML
    });

    FB.getLoginStatus(function (response) {

        if (response.status === 'connected') {
            if (response.authResponse) {

                var fb_access_token = response.authResponse.accessToken; // I even tried hard-coding the value from: https://graph.facebook.com/oauth/access_token?type=client_cred

                FB.api(
                    {
                        method: 'fql.query',
                        query: 'SELECT xid,count FROM comments_info WHERE app_id="'+fb_app_id+'"',
                        access_token : fb_access_token
                    },
                    function(newresponse) {
                        $.each(newresponse, function(i, e) {
                             $("#fbcomments").append(""+e.text+""); // we get here, but e.text is undefined (see my error on top)
                        });         

                    }
                ); //FB.api
                    } else { //response.authResponse
                        console.log('no response.authResponse');// do something...maybe show a login prompt
                    }
            } else if (response.status === 'not_authorized') {
                console.log(' not_authorized')
            } else {
                console.log('not_logged_in')
            }
    });
};

</script>
 <script type="text/javascript"> (function(d){ var js, id = 'facebook-jssdk'; if (d.getElementById(id)) {return;} js = d.createElement('script'); js.id = id; js.async = true;js.src = "//connect.facebook.net/he_IL/all.js#appId=*&amp;xfbml=1";d.getElementsByTagName('head')[0].appendChild(js); }(document)); </script>

ノート:

  1. を使用するアプリの管理者ですapp_id
  2. この現在のタスクが成功したら、この FQL クエリをテーブルcommentsと一致するようにラップして、XID.
  3. 標準graph.facebookを使用すると、特定のページ URL のコメントのみが返されます。私のウェブサイトに寄せられたすべてのコメントが欲しいです。
  4. Facebook コメント モデレーション ツールを iFrame したくありません。

私は試した:

  1. 使う・使わないFB.init({'session'...}
  2. ハードコーディング fb_access_token
  3. #app_id=*値で使用する場合と使用しない<script src="">場合。
  4. Facebook からのログアウト、ログインなど。
  5. このクエリを実行するまで数日 (場合によっては 2 週間) 待ちます。

アップデート:

PHPも使用しましたが、同じエラーが発生しました。これは私のPHPスクリプトです:

// get user access_token
$token_url = "https://graph.facebook.com/oauth/access_token?client_id=$app_id&client_secret=$app_secret&grant_type=client_credentials";

// response is of the format "access_token=AAAC..."
$access_token = substr(file_get_contents($token_url), 13);

$config = array(
        'appId'  => $app_id,
        'secret' => $app_secret
);
$facebook = new Facebook($config);

$user_id = $facebook->getUser();

if ($user_id) {
    $params = array(
            'method' => 'fql.query',
            'query' => "SELECT xid,count FROM comments_info WHERE app_id=$app_id",
            'access_token' => $access_token
    );

    try {
        $result = $facebook->api($params);
        var_dump($result);
    } catch (Exception $e) {
        var_dump($e);
    }


} else {
    $login_url = $facebook->getLoginUrl();
    echo 'Please <a href="' . $login_url . '">login.</a>';
}

何も機能していないようです。何が問題なのですか?

4

0 に答える 0