$ facebook-> getSession () на странице Facebook iframe приложение / вкладка работает только тогда, когда администратор приложения вошел в систему - PullRequest
0 голосов
/ 17 марта 2011

Я разрабатываю несколько пользовательских страниц iframe / canvas (или теперь называемых «приложениями») для бизнес-страницы Facebook.В моих целях я хотел бы получить имя и фамилию пользователя, который в данный момент вошел в систему (и в данный момент любит страницу), и вывести его на страницу.Этот скрипт прекрасно работает, когда я вошел в систему как администратор приложения, но когда я пытаюсь войти в систему как личный аккаунт или как аккаунт нескольких моих друзей - кажется, что $ session is null.Почему это происходит и как я могу получить имя и фамилию, не заставляя пользователя проходить дополнительную аутентификацию?

<?php
require_once '../db/connect.php';
require_once '../../lib/facebook.php';
$signed_request = $_REQUEST["signed_request"];
$secret = "***********************************";
$facebook = new Facebook(array(
    'appId'  => '**************',
    'secret' => $secret,
    'cookie' => true
));
$session = $facebook->getSession();
$me = null;
// Session based API call.
if ($session) {
    echo "\$session is not null!";
    try {
        $uid = $facebook->getUser();
        $me = $facebook->api('/me');
    } catch (FacebookApiException $e) {
        error_log($e);
    }
}
echo $me['name'];
?>

1 Ответ

1 голос
/ 17 марта 2011

К сожалению, это невозможно ( ссылка ):

Как и в случае с страницей холста, вы не получите всю пользовательскую информацию, доступную для вашего приложения в signed_request пока пользователь не авторизует ваше приложение.

Итак, вам нужно, чтобы пользователь сначала авторизовал ваше приложение, это можно найти здесь :

 <?php 

     $app_id = YOUR_APP_ID;

     $canvas_page = YOUR_CANVAS_PAGE_URL;

     $auth_url = "http://www.facebook.com/dialog/oauth?client_id=" 
            . $app_id . "&redirect_uri=" . urlencode($canvas_page);

     $signed_request = $_REQUEST["signed_request"];

     list($encoded_sig, $payload) = explode('.', $signed_request, 2); 

     $data = json_decode(base64_decode(strtr($payload, '-_', '+/')), true);

     if (empty($data["user_id"])) {
            echo("<script> top.location.href='" . $auth_url . "'</script>");
     } else {
            echo ("Welcome User: " . $data["user_id"]);
     } 
 ?>

После авторизации приложения и получения идентификатора пользователяЯ полагаю, этот процесс тривиален.

...