我在我的应用程序中集成了google和facebook oauth。 首先,我像谷歌一样为这个
启动了这个课程$client = new Google_Client();
$client->setApplicationName("urmk google login");
$oauth2 = new Google_Oauth2Service($client);
if (isset($_GET['code'])) {
$client->authenticate($_GET['code']);
$_SESSION['token'] = $client->getAccessToken();
$redirect = 'http://' . $_SERVER['HTTP_HOST'] . $_SERVER['PHP_SELF'];
header('Location: ' . filter_var($redirect, FILTER_SANITIZE_URL));
return;
}
Google登录过程工作正常,我也可以获取用户信息。但 然后我整合了facebook oauth
FacebookSession::setDefaultApplication('APP_ID', 'APP_SECRET');
$helper = new FacebookRedirectLoginHelper('http://example.com/');
$loginUrl = $helper->getLoginUrl();
try {
$session = $helper->getSessionFromRedirect();
} catch(FacebookRequestException $ex) {
// When Facebook returns an error
} catch(\Exception $ex) {
// When validation fails or other local issues
}
if ($session) {
// Logged in
$user = $facebook->getUser();
if ($user) {
try {
$user_profile = $facebook->api('/me');
} catch (FacebookApiException $e) {
error_log($e);
$user = null;
}
}
if ($user) {
$logoutUrl = $facebook->getLogoutUrl();
} else {
$loginUrl = $facebook->getLoginUrl();
}
}
它成功地将我带到用户帐户,它要求用户权限,但在重定向到我的网站时会抛出错误
Fatal error: Uncaught exception 'Google_AuthException' with message
'Error fetching OAuth2 access token, message: 'invalid_grant'' in
C:\xampp\htdocs\urmk\lib\src\auth\Google_OAuth2.php:113 Stack trace:
#0 C:\xampp\htdocs\urmk\lib\src\Google_Client.php(131):
Google_OAuth2->authenticate(Array, 'AQASSzhhLhYIYxI...') #1
C:\xampp\htdocs\urmk\index.php(66):
Google_Client->authenticate('AQASSzhhLhYIYxI...') #2 {main} thrown in
C:\xampp\htdocs\urmk\lib\src\auth\Google_OAuth2.php on line 113**
再次,如果我将 if(isset($ _ GET ['code']))更改为 if(isset($ _ GET ['something else']))。它工作正常。那么如何解决这个错误。任何帮助将不胜感激。
答案 0 :(得分:0)
我认为问题在于您在“身份验证”中有参数。功能调用。根据我在Google代码中看到的Google_OAuth2.php',它自己称之为。您需要确保设置变量。看看下面的代码。
还要确保使用正确版本的Google代码...在线与已安装。我读到安装版本是Native。
if(isset($_GET['code']))
{
$client->authenticate();
$_SESSION['access_token'] = $client->getAccessToken();
header('Location: http://' . $_SERVER['HTTP_HOST'] . $_SERVER['PHP_SELF']);
}
您可以通过...
设置访问令牌if(isset($_SESSION['access_token']))
{
$client->setAccessToken($_SESSION['access_token']);
}
如果一切都失败了,请阅读本文件...... http://25labs.com/tutorial-implementing-google-api-using-oauth-2-0-in-php/
此外,捕获异常,这样您至少可以获得一个或另一个作为成功的身份验证,而不是一起错误。