0
<?php

require 'facebook/facebook.php';
require 'config/fbconfig.php';
require 'config/functions.php';

define('APP_ID', '******************');
define('APP_SECRET', '***********************');

$facebook = new Facebook(array(
            'appId' => '******************',
            'secret' => '***********************',
            'cookie' => true
        ));

$session = $facebook->getSession();



if (!empty($session)) {
    # Active session, let's try getting the user id (getUser()) and user info (api->('/me'))
    try {

        $uid = $facebook->getUser();
        print_r($uid);
        $user = $facebook->api('/me');
        facebook::$CURL_OPTS[CURLOPT_SSL_VERIFYPEER] = false; 
        facebook::$CURL_OPTS[CURLOPT_SSL_VERIFYHOST] = 2;
    } catch (Exception $e) {




    }

    if ($user) {
        # User info ok? Let's print it (Here we will be adding the login and registering routines)
        echo '<pre>';
        print_r($user);
        echo '</pre><br/>';
        $username = $user['name'];
        $user = new User();
        $userdata = $user->checkUser($uid, 'facebook', $username);
        if(!empty($userdata)){
            session_start();
            $_SESSION['id'] = $userdata['id'];
 $_SESSION['oauth_id'] = $uid;

            $_SESSION['username'] = $userdata['username'];
            $_SESSION['oauth_provider'] = $userdata['oauth_provider'];
            header("Location: home.php");
        }
    } else {
        # For testing purposes, if there was an error, let's kill the script

        die("There was an error.");
    }
} else {
    # There's no active session, let's generate one
   // $login_url = $facebook->getLoginUrl();
     $loginUrl = $facebook->getLoginUrl( array(
                           'canvas'    => 1,
                           'fbconnect' => 0,
                           'req_perms' => 'email,publish_stream',
                       'next' => 'http://localhost/login_twitbook/',
                              'cancel_url' => 'http://localhost/login_twitbook/'
                      ) );
    header("Location: " . $login_url);
}
?>

$user = $facebook->api('/me'); 正しく動作していないため、常に何も返されません。この問題を解決するのを手伝ってください。私は localhost.$uid = $facebook->getUser() で作業していますが、値は返されますが、$user は返されません

4

1 に答える 1

0

base_facebook.php ファイルの getCode 関数を変更して、すべての $_REQUEST を $_GET に変更してみてください。これがまだ修正されていない理由はわかりませんが、これを行うまでユーザーに 0 を返す理由を突き止めようとして髪を引っ張っていましたが、今では問題なく動作します。

ファイルの 680 行目付近にある必要があり、変更する必要があるのは 4 つあります。

  protected function getCode() {
if (isset($_GET['code'])) {
  if ($this->state !== null &&
      isset($_GET['state']) &&
      $this->state === $_GET['state']) {

    // CSRF state has done its job, so clear it
    $this->state = null;
    $this->clearPersistentData('state');
    return $_GET['code'];
  } else {
    self::errorLog('CSRF state token does not match one provided.');
    return false;
  }
}

return false;

}

于 2012-10-18T11:47:24.447 に答える