Приложение Facebook canvas "redirect_uri" выходит из iframe после авторизации и аутентификации - PullRequest
9 голосов
/ 30 сентября 2011

Я модернизирую свои существующие приложения FB и совершенно безумно стараюсь получить простое PHP-приложение iframe canvas для авторизации и аутентификации (а также использования SSL).Никогда не просматривал так много примеров ...

Вот где я застрял: после того, как пользователь авторизует приложение, а приложение аутентифицирует пользователя (я могу сделать запрос графа с токеном OK),происходит редирект_ури, и вся страница обновляется, оставляя Facebook, а затем просто показывает мне содержимое моей страницы «URL-адрес холста» (с доменом моего сервера), а не вставляется в фрейм в Facebook.грубый двухэтапный процесс ...

Вот как мой код выглядит на первой странице (index.php):

<?php
require('src/facebook.php');

$app_id = '123456789';
$app_secret = '1234secrets1234';
$canvas_page = "https://apps.facebook.com/123456789/";
$canvas_url = "https://myserver.com/apptest/";

$code = $_REQUEST['code'];

if(!$code){
$display= 'page';
$scope= 'manage_pages, offline_access, read_insights, publish_stream, user_about_me, user_likes, email'; 
$redirect_url = 'https://myserver.com/apptest/step2.php';
$oauth_url    = 'https://www.facebook.com/dialog/oauth?canvas=1&client_id='.$app_id.'&display='.$display.'&redirect_uri='.urlencode($redirect_url).'&scope='.$scope;
$config = array('appId'  => $app_id,'secret' => $app_secret,'cookie' => true,'domain' => true);
$facebook_client = new Facebook($config);

echo "<script type=\"text/javascript\">top.location.href = \"".$oauth_url."\";</script>";
}
?>

и на второй странице (step2.php):

<?php
require('src/facebook.php');

$app_id = '123456789';
$app_secret = '1234secrets1234';
$canvas_page = "https://apps.facebook.com/123456789/";
$canvas_url = "https://myserver.com/apptest/";


if($_REQUEST['code']){
$code=$_REQUEST['code'];
$redirect_url = 'https://myserver.com/apptest/step2.php';
$link="https://graph.facebook.com/oauth/access_token?canvas=1&client_id=".$app_id."&redirect_uri=".urlencode($redirect_url)."&client_secret=".$app_secret."&code=".$code;
$string = file_get_contents($link);
$auth_token=substr($string, 13, 150);

$graph_url = "https://graph.facebook.com/me?access_token=".$auth_token;
$user = json_decode(file_get_contents($graph_url));
echo("Hello " . $user->name);
} 

Опять же, как только пользователь авторизовал приложение, и приложение аутентифицировало пользователя, вызов графа работает.

Есть идеи?

Ответы [ 2 ]

6 голосов
/ 30 сентября 2011

При переходе к диалоговому окну OAuth веб-страница (а не фрейм, в котором находится ваше приложение) перемещается по URL-адресу OAuth.Чтобы вернуться в iframe Facebook после аутентификации, вам нужно установить URL перенаправления OAuth на URL canvas_page.Приведенный выше код выполняет переход к URL-адресу myserver при перенаправлении, поэтому ваше приложение занимает всю страницу (потому что вы оставили Facebook iframe при переходе к диалоговому окну OAuth).Ваш код на canvas_url должен определить, вводится ли он из авторизации (успех или неудача) или вводится ли он с действительным токеном доступа после аутентификации.

Кроме того, ваш URL-адрес canvas_page, похоже, состоит из facebookхост приложений и идентификатор вашего приложения.Это должен быть хост приложений facebook и имя вашего приложения (URL перенаправления должен совпадать с URL-адресом «Canvas Page» на странице разработчика вашего приложения).

1 голос
/ 30 сентября 2011

Ну, я все заработал. В приложении> настройки> базовые я не задал пространство имен, поэтому URL-адрес, который он мне дал для приложения на Facebook, выглядел следующим образом: https://apps.facebook.com/123456789/, и теперь с пространством имен они изменили его на: https://apps.facebook.com/myappname. Так что, возможно, так оно и было. Я попытался тщательно следовать простой демонстрации авторизации PHP на этой странице: https://developers.facebook.com/docs/appsonfacebook/tutorial/, и теперь она работает нормально.

Спасибо за помощь!

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