0

ここでこのコードを見つけましたhttp://developers.facebook.com/docs/authentication/

<?php 

   $app_id = "YOUR_APP_ID";
   $app_secret = "YOUR_APP_SECRET";
   $my_url = "YOUR_URL";

   session_start();
   $code = $_REQUEST["code"];

   if(empty($code)) {
     $_SESSION['state'] = md5(uniqid(rand(), TRUE)); //CSRF protection
     $dialog_url = "http://www.facebook.com/dialog/oauth?client_id=" 
       . $app_id . "&redirect_uri=" . urlencode($my_url) . "&state="
       . $_SESSION['state'];

     echo("<script> top.location.href='" . $dialog_url . "'</script>");
   }

   if($_REQUEST['state'] == $_SESSION['state']) {
     $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);

     $graph_url = "https://graph.facebook.com/me?access_token=" 
       . $params[‘access_token’];

     $user = json_decode(file_get_contents($graph_url));
     echo("Hello " . $user->name);
   }
   else {
     echo("The state does not match. You may be a victim of CSRF.");
   }

?>

変更したのは、アプリ ID アプリ シークレットと URL でした。1 つの HTML 文でページを作成しました。これを Web サーバーにアップロードしたところ、ページが見つかりませんというエラーが表示されました。誰でもそれで私を助けることができますか?また、何かを含める必要がありますか?

4

3 に答える 3

2

FacebookSDKを使用する必要があります。これがサンプルチュートリアルで、うまくいきます。

http://www.9lessons.info/2011/01/facebook-graph-api-connect-with-php-and.html

私はそれがあなたの問題を解決すると確信しています。

于 2011-05-23T05:21:36.843 に答える
2

コードでやろうとしていることは、すでに存在するものの一種の回避策です。今試していることについては、 Facebook PHP SDKを使用してください。それは物事をはるかに簡単にし、おそらくより短い時間で目標に到達します.

于 2011-05-23T05:33:01.470 に答える
1

Facebook PHP SDK ( github を参照) を使用する必要があります。ユーザーのログインを処理するのは非常に簡単です。次のようになります。

require 'facebook.php';
$facebook = new Facebook(...);

$user = $facebook->getUser();

ユーザーがログインしている場合、$user彼の Facebook ID が含まれます。ただし、API 呼び出しを行うための有効なアクセス トークンがあることを意味するわけではありません。Facebook からログアウトしたばかりの場合、$usernull にはなりませんが、アクセス トークンは無効になります。

有効なトークンを持っているかどうかを確認する 1 つの方法は、実際に API 呼び出しを行うことです。

if ($user) {
  // The user is logged in
  try {
    $facebook->api('/me');
    // Here : API call succeeded, you have a valid access token
  } catch (FacebookApiException $e) {
    // Here : API call failed, you don't have a valid access token
    // you have to send him to $facebook->getLoginUrl()
    $user = null;
  }
} else {
  // The user is not logged
  // you have to send him to $facebook->getLoginUrl()
}

次に、ユーザーにログインするか、有効なアクセス トークンを取得します。

if (!$user) {
  // display link to $facebook->getLoginUrl();
}

Facebook PHP SDK の例を確認して、完全なフローを確認することをお勧めします。十分に文書化されています。

それが役立つことを願っています。

于 2011-05-27T10:14:41.130 に答える