API Facebook изменен - PullRequest
       3

API Facebook изменен

2 голосов
/ 19 августа 2011

Я пытаюсь войти в систему на Facebook с помощью автономного токена (у меня он долго работал), но, может быть, Facebook что-то изменил?

Быстрый прогон: У меня была аутентификация Facebook PHP SDK (2.1) через OAuth. Я помню, что возвращенные данные после получения токена доступа были примерно такими:

callbackurl?session={access_token:....,expires:....,session_key....}

и т. Д. В основном объект JSON в URL.

Но теперь кажется, что они изменили параметры, и все, что я получаю, это что-то вроде этого:

[fb_199972360033499_access_token] What are these digits?
[fb_199972360033499_user_id]

(я пробовал с (PHP SDK 2.1 и 3.1.1)

Ранее я сохранял настройку сохраненных данных токена с помощью

$facebook->setSession($dataArray); 

Но теперь я больше не знаю, что делать, если у кого-то есть какие-либо подсказки, где искать, я был бы признателен, так как мне трудно найти правильную инструкцию в реальной документации FB.

Ответы [ 2 ]

2 голосов
/ 19 августа 2011

Давайте используем новый PHP-SDK , чтобы получить токен доступа:

<code><?php
/**
 * Copyright 2011 Facebook, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); you may
 * not use this file except in compliance with the License. You may obtain
 * a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations
 * under the License.
 */

require './src/311/facebook.php';

// Create our Application instance (replace this with your appId and secret).
$facebook = new Facebook(array(
  'appId'  => 'APP_ID',
  'secret' => 'APP_SECRET',
));

// Get User ID
$user = $facebook->getUser();
// We may or may not have this data based on whether the user is logged in.
//
// If we have a $user id here, it means we know the user is logged into
// Facebook, but we don't know if the access token is valid. An access
// token is invalid if the user logged out of Facebook.

if ($user) {
  try {
    // Proceed knowing you have a logged in user who's authenticated.
    $user_profile = $facebook->api('/me');
  } catch (FacebookApiException $e) {
    error_log($e);
    $user = null;
  }
}

// Login or logout url will be needed depending on current user state.
if ($user) {
  $logoutUrl = $facebook->getLogoutUrl();
} else {
  $loginUrl = $facebook->getLoginUrl(array('scope'=>'offline_access'));
}
?>
<!doctype html>
<html xmlns:fb="http://www.facebook.com/2008/fbml">
  <head>
    <title>php-sdk</title>
    <style>
      body {
        font-family: 'Lucida Grande', Verdana, Arial, sans-serif;
      }
      h1 a {
        text-decoration: none;
        color: #3b5998;
      }
      h1 a:hover {
        text-decoration: underline;
      }
    </style>
  </head>
  <body>
    <h1>php-sdk</h1>

    <?php if ($user): ?>
      <a href="<?php echo $logoutUrl; ?>">Logout</a>
    <?php else: ?>
      <div>
        Login using OAuth 2.0 handled by the PHP SDK:
        <a href="<?php echo $loginUrl; ?>">Login with Facebook</a>
      </div>
    <?php endif ?>

    <h3>PHP Session</h3>
    <pre><?php print_r($_SESSION); ?>

Вы

image/picture">

Ваш пользовательский объект (/ me)

<?php print_r($user_profile); ?>
Вы не подключены.

Вот пара замечаний:

  • Мы запросили разрешение offline_access при создании URL-адреса для входа в систему
  • как только вы войдете в систему, вы получите access_token (вы сказали, что он у вас уже есть, поэтому продолжайте чтение)

Теперь выйдите из Facebook и давайте использовать access_token:

<code><?php
require './src/311/facebook.php';

$facebook = new Facebook(array(
  'appId'  => 'APP_ID',
  'secret' => 'APP_SECRET',
));

$offline_access_token = "XXXXXX";
try {
    $user_profile = $facebook->api('/me', 'GET', array('access_token'=>$offline_access_token));
    echo "<pre>";
    print_r($user_profile);
    echo "
";} catch (FacebookApiException $ e) {error_log ($ e);}?>
2 голосов
/ 19 августа 2011

Новый PHP SDK

Для примеров использования нового PHP SDK вы должны посмотреть:

https://github.com/facebook/php-sdk

http://developers.facebook.com/blog/post/534/

Также полезно взглянуть на исходный код.

Автономный доступ

http://developers.facebook.com/docs/authentication/

Если у вас есть авторизованный пользователь, теперь вы можете получить пользователя access_token с:

$access_token = $facebook->getAccessToken();

Если авторизованный пользователь недоступен, он вернет токен доступа к приложению.

Если вашему приложению нужен токен доступа с неограниченным сроком действия (возможно, для выполнения действий от имени пользователя после того, как он не использует ваше приложение), вы можете запросить разрешение offline_access.

Чтобы получить идентификатор пользователя:

$user_id = $facebook->getUser();

Идентификатор приложения

[fb_199972360033499_access_token] Что это за цифры?

Эти цифры должны быть идентификатором вашего приложения.

Постоянные данные

$ facebook-> setSession ($ DataArray);

В этом больше нет необходимости, поскольку PHP SDK позаботится об этом. Если вы не хотите хранить свои собственные данные - в этом случае вы должны создать свои собственные данные сеанса.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...