-3

Facebookの開発者が提供する手順を使用してみました。

http://developers.facebook.com/docs/howtos/login/server-side-login/

ただし、リダイレクト後、基本的なphpページにリダイレクトすることはできません。私のコードに何か問題がありますか?

これが私のコードです:

require_once 'library/facebook.php';
    $facebook = new Facebook(array(
    'appId'  => '*** My APP ID ***',
    'secret' => '*** My Secret ***',                
    'fileUpload' => true
));

$my_url = "https://apps.facebook.com/carnumberchecking";
session_start();

$user = $facebook->getUser();
$me = null;

if($user)
{
$uid = $facebook->getUser();
}else{
$url = $facebook ->getLoginUrl( array (
'scope' => 'publish_stream',
'req_perms' => 1,
'fbconnect' => 0
 ));
 echo "";                
}                  

$code = $_REQUEST["code"];
if(empty($code)) {  
$_SESSION['state'] = md5(uniqid(rand(), TRUE)); // CSRF protection  
$dialog_url = "https://www.facebook.com/dialog/oauth?    client_id=187384241402698&redirect_uri=" . urlencode($my_url) . "&state="
                . $_SESSION['state'] . "&scope=user_birthday,read_stream";
echo("<script> top.location.href='" . $dialog_url . "'</script>");
}

if($_SESSION['state'] && ($_SESSION['state'] === $_REQUEST['state'])) {
echo "1";
$token_url = "https://graph.facebook.com/oauth/access_token?"
        . "client_id=187384241402698&redirect_uri=" . urlencode($my_url)
        . "&client_secret=4e45477f9ed79f95fc4fd3af8f8a579d&code=" . $code;

$response = file_get_contents($token_url);
$params = null;
parse_str($response, $params);
}
4

1 に答える 1

1

インターネット上のさまざまな情報源から見つけたものを混ぜているようです..ほとんどが時代遅れのチュートリアルなどです.

公式の facebook PHP-SDK を使用する予定の場合、これはログイン プロセスの簡単な例です: https://github.com/facebook/facebook-php-sdk/blob/master/examples/example.php

それ以外の場合は、上記のリンクに従って、上記のサンプル スニペットをコンパイルするだけで、完全に動作する例が得られるはずです!!:

<?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 = "https://www.facebook.com/dialog/oauth?client_id=" 
       . $app_id . "&redirect_uri=" . urlencode($my_url) . "&state="
       . $_SESSION['state'] . "&scope=read_stream";

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

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

     $_SESSION['access_token'] = $params['access_token'];

     $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.");
   }

ここに APP_ID、APP_SECRET、およびリダイレクト URL を配置する必要があります...また、パーミッション (スコープ) を変更したり、すべて一緒に削除したりすることもできます。

于 2013-01-10T14:04:25.783 に答える