2016-11-27 52 views
-1

我檢查了所有與此相關的Stackoverflow上一個問題。但他們沒有一個像我的一樣。 我爲我的網站實施了Facebook登錄。它的工作很好。但問題是登錄後,頁面重定向到Facebook主頁,而不是重定向到我的網站。php - Facebook登錄後重定向不起作用

我的代碼如下。我沒有從Facebook開發者的官方文檔中改變太多。

的login.php

<?php 

session_start(); 
require_once __DIR__ . '/Facebook/autoload.php'; 
$fb = new Facebook\Facebook([ 
    'app_id' => '****', 
    'app_secret' => '****', 
    'default_graph_version' => 'v2.2', 
    ]); 

$helper = $fb->getRedirectLoginHelper(); 
$permissions = ['email', 'user_likes']; // optional 
$loginUrl = $helper->getLoginUrl('http://example.com/login-callback.php', $permissions); 

echo '<a href="' . $loginUrl . '">Log in with Facebook!</a>'; 

?> 

登錄-callback.php

<?php 

# login-callback.php 
session_start(); 
require_once __DIR__ . '/Facebook/autoload.php'; 
$fb = new Facebook\Facebook([ 
    'app_id' => '****', 
    'app_secret' => '****', 
    'default_graph_version' => 'v2.2', 
    ]); 

$redirectloc = $_SERVER['HTTP_REFERER']; 
$helper = $fb->getRedirectLoginHelper(); 
try { 
    $accessToken = $helper->getAccessToken(); 
} catch(Facebook\Exceptions\FacebookResponseException $e) { 
    // When Graph returns an error 
    echo 'Graph returned an error: ' . $e->getMessage(); 
    exit; 
} catch(Facebook\Exceptions\FacebookSDKException $e) { 
    // When validation fails or other local issues 
    echo 'Facebook SDK returned an error: ' . $e->getMessage(); 
    exit; 
} 


if (isset($accessToken)) { 
    // Logged in! 
    $_SESSION['facebook_access_token'] = (string) $accessToken; 
    header("Location:$redirectloc"); 
exit(); 
    // Now you can redirect to another page and use the 
    // access token from $_SESSION['facebook_access_token'] 
} elseif ($helper->getError()) { 
    // The user denied the request 
    exit; 
} 

?> 

當我登錄已經在我的Facebook帳戶從同一個瀏覽器,並試圖從我的網站登錄,其完美地工作。 即header("Location:$redirectloc");在login-callback.php中按預期工作。它重定向到login.php。

現在,如果我從我的Facebook帳戶從瀏覽器註銷,並嘗試從我的網站登錄,其要求Facebook的身份證和密碼這是正常的。

但輸入用戶名和密碼後,它重定向到Facebook主頁,而不是重定向到login.php。

+3

嗯,因爲referer包含Facebook的網址。您需要的是在會話中保存位置,然後調出舊位置並將用戶重定向到該位置。 –

+0

太好了,我硬編碼重定向代碼及其工作。謝謝。現在我知道問題在哪裏。但如何重定向到登錄後確切的上一頁? – Arijit

+0

@CharlotteDunois請將它作爲答案發布,以便我可以接受它。 – Arijit

回答

1

這個問題來自引用者,並且是預期的。瀏覽器發送的引用程序包含它來自的URL。由於您在Facebook上,引用者將包含網址facebook.com(可能不僅僅是域名)。如果您忽略重定向到facebook.com(由於已經登錄),則引用者包含您網站上次訪問的頁面。

此問題的解決方案是,在將用戶重定向到Facebook之前,將會話保存在會話中,然後重定向到Facebook。然後在login-callback.php中,您可以從會話中讀取重定向位置,並將其用於header("Location: ...")