Uaktualniam moje istniejące aplikacje FB i robię absolutne obrażenia próbując uzyskać prostą aplikację Canvas iframe w PHP, aby autoryzować i uwierzytelniać (jak również używać SSL) . Nigdy nie przeglądałem tylu przykładów ...Facebookowa aplikacja na płótnie "redirect_uri" zrywa się z elementu iframe po autoryzacji i uwierzytelnieniu
Oto, gdzie utknąłem: Po autoryzacji aplikacji przez użytkownika, a aplikacja uwierzytelnia użytkownika (jestem w stanie wykonać żądanie wykresu z tokenem w porządku), redirect_uri dzieje się, a cała strona odświeża się, pozostawiając Facebooka, a następnie po prostu pokazuje mi zawartość mojej strony "Canvas URL" (z domeną mojego serwera), zamiast iframed na Facebooku.
Obecnie mam to w postaci surowego procesem dwuetapowym ...
Oto co mój kod wygląda na pierwszej stronie (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>";
}
?>
i drugiej strony (Krok 2 .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);
}
Ponownie, gdy użytkownik autoryzuje aplikację, a aplikacja uwierzytelniła użytkownika, działa połączenie graficzne.
Wszelkie pomysły?
możliwy duplikat [Dlaczego dostaję niezdefiniowany indeks dla signed_request w mojej aplikacji na Facebooku?] (Http://facebook.stackoverflow.com/questions/7534241/why-do-i-get-an-undefined-index -for-signed-request-in-my-facebook-app) – ifaour