9

PHP を使用して Facebook アプリケーション (apps.facebook.com/some_app) を開発しようとしています。ユーザーの音楽の興味に基づいて情報を提示する必要があります。「user_likes > games」の下にあることがわかりました。

私の問題は次のとおりです。

  • アクセスするために、インデックス ページの API で提案されているように、oauth ダイアログ メソッドを実装しました。

$auth_url = "http://www.facebook.com/dialog/oauth?client_id="
            . $app_id . "&redirect_uri=" 
            . urlencode($canvas_page)
            ."&scope=user_likes";
  • 認証が成功すると、「コード」をパラメータとしてインデックス ページに戻ります。

http://MY_CANVAS_PAGE/?code=some base64 encoded letters
  • まず、ユーザーの音楽への関心を読み取るためだけに access_token が必要かどうかはわかりませんが、提案されたすべての方法を試しました。ここから先に進めませんでした
  • コードパラメータが設定されていない場合、承認のためにリダイレクトするこのようなコードがあります(私のインデックスページにあります)。

if(empty($code) && !isset($_REQUEST['error'])) {
  $_SESSION['state'] = md5(uniqid(rand(), TRUE)); //CSRF protection
  echo("<script> top.location.href='" . $auth_url . "'</script>");
}
  • 現在、ここでユーザーの公開情報を取得しようとしていますが、成功していません。提案どおりに signed_request メソッドを試しましたが、成功しませんでした

$signed_request = $_REQUEST["signed_request"];
list($encoded_sig, $payload) = explode('.', $signed_request, 2);
$data = json_decode(base64_decode(strtr($payload, '-_', '+/')), true);
echo ("Welcome User: " . $data["user_id"]);

print_r($decoded_response);

stdClass Object ( [error] => stdClass Object ( [message] => An active 
access token must be used to query information about the current user. 
[type] => OAuthException [code] => 2500 ) ) 

ユーザーの公開情報を取得するために、PHP SDK で提案されている例も試しました


$facebook = new Facebook(array(
'appId'  => MY_APP_ID, //registered facebook APP ID
'secret' => MY_SECRET, //secret key for APP
));

$fb_user = $facebook->getUser();

if($fb_user){
    try {
      $user_profile = $facebook->api('/me');
      echo $user_profile['email'];
    }
    catch(FacebookApiException $e) {
      $fb_user = null;
    }
}

しかし、成功しません。このエラーが発生する理由と、ユーザーの音楽への関心に適切にアクセスする方法を誰かが説明してくれませんか? おそらく私はAPIを誤解していました。

ありがとう

ディーパック

4

4 に答える 4

9

エラー 2500 は、アクセス トークンがないか、アプリ アクセス トークンがないにもかかわらずアクセスしようとしていることを意味します。/me/「me」は「現在のユーザーまたはページ ID」のプレースホルダーであるため、ユーザーまたはページのアクセス トークンがないと有効になりません。

ユーザーのいいねのリストにアクセスするには、それらを承認するときにuser_likes パーミッションも必要です

codeアプリがアクセス トークンと交換できない原因として最も可能性が高いのは次のとおりです。

  1. 使用redirect_uriした はフォルダーまたはサーバー ルートに対してであり、末尾のスラッシュがありません (つまり、http://www.example.com代わりにhttp://www.example.com/)
  2. 認証ダイアログへの最初の呼び出しで使用したものは、access_token のコードを交換するための呼び出しで使用したものredirect_uriと正確には同じではありませんでしたredirect_uri

何らかの理由で認証フローが壊れていて、SDK の例や認証のドキュメントからそれを理解できない場合は、理解するために必要な背景知識が不足している可能性があるため、誰かがあなたに説明するのに時間がかかる可能性があります。答え

于 2012-06-17T21:52:19.687 に答える
1

私にとっては、php で認証トークンを取得しようとしていたところ、2500 エラーはfile_get_contents何も返さないという問題によるものであることがわかりました。ブラウザで URL にアクセスできましたが、file_get_contents. ここで説明されているように、代わりに CURL を使用して修正しました: https://stackoverflow.com/a/6325313

その結果、https://developers.facebook.com/docs/authentication/server-side/のコードを使用し、次の行を置き換えました。

$response = file_get_contents($token_url);

$ch = curl_init($token_url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$response = curl_exec($ch);

したがって、次のようになりました。

   $token_url = "https://graph.facebook.com/oauth/access_token?client_id="
        . $app_id . "&redirect_uri=" . urlencode($redirect_url)
        . "&client_secret=" . $app_secret
        . "&code=" . $code;

    /* Facebook say to use this, but file_get_contents isn't working!
    $response = file_get_contents($token_url,null, $val);
    */

    // Use this as an alternative
    $ch = curl_init($token_url);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    $response = curl_exec($ch);

    // From https://developers.facebook.com/docs/authentication/server-side/
    $params = null;
    parse_str($response, $params);
    $access_token = $params['access_token'];
于 2012-06-20T09:39:25.807 に答える
0

このコードを試してください

$code = $_REQUEST["code"];
  if(empty($code)) {
    $dialog_url = "http://www.facebook.com/dialog/oauth?client_id=" 
    . $app_id . "&redirect_uri=" . urlencode($my_url) ;
    echo("<script>top.location.href='" . $dialog_url . "'</script>");
  }

  $token_url = "https://graph.facebook.com/oauth/access_token?client_id="
    . $app_id . "&redirect_uri=" . urlencode($my_url) 
    . "&client_secret=" . $app_secret 
    . "&code=" . $code;
    $response = file_get_contents($token_url);
    $params = null;
    parse_str($response, $params);
    $access_token = $params['access_token'];

PS: ユーザーのメール アドレスは公開情報ではありません。そのための user_email 権限が必要です。

于 2012-02-20T06:25:49.643 に答える