从 Google OAuth 2.0 PHP API 获取用户信息

Posted

技术标签:

【中文标题】从 Google OAuth 2.0 PHP API 获取用户信息【英文标题】:Get Userinfo from Google OAuth 2.0 PHP API 【发布时间】:2012-12-10 01:29:24 【问题描述】:

我正在尝试使用 Google Oauth API 来获取用户信息。 它非常适用于 Google Plus API,但我正在尝试创建一个备份,以防用户没有 google plus 帐户。 身份验证过程是正确的,我什至得到了 $userinfo 对象,但我究竟如何访问这些属性。我试过 $userinfo->get() 但它只返回用户的 id。

我做错了吗?这是我正在使用的代码...

require_once '../../src/Google_Client.php';
require_once '../../src/contrib/Google_Oauth2Service.php';

session_start();

$client = new Google_Client();
$client->setApplicationName("Google+ PHP Starter Application");
// Visit https://code.google.com/apis/console to generate your
// oauth2_client_id, oauth2_client_secret, and to register your oauth2_redirect_uri.
 $client->setClientId('*********************');
 $client->setClientSecret('**************');
 $client->setRedirectUri('***************');
 $client->setDeveloperKey('**************');
$plus = new Google_Oauth2Service($client);

if (isset($_REQUEST['logout'])) 
  unset($_SESSION['access_token']);


if (isset($_GET['code'])) 
  $client->authenticate($_GET['code']);
  $_SESSION['access_token'] = $client->getAccessToken();
  header('Location: http://' . $_SERVER['HTTP_HOST'] . $_SERVER['PHP_SELF']);


if (isset($_SESSION['access_token'])) 
  $client->setAccessToken($_SESSION['access_token']);


if ($client->getAccessToken()) 

    $userinfo = $plus->userinfo;
    print_r($userinfo->get());

 else 

    $authUrl = $client->createAuthUrl();

?>
<!doctype html>
<html>
<head>
  <meta charset="utf-8">
  <link rel='stylesheet' href='style.css' />
</head>
<body>
<header><h1>Google+ Sample App</h1></header>
<div class="box">

<?php if(isset($personMarkup)): ?>
<div class="me"><?php print $personMarkup ?></div>
<?php endif ?>

<?php
  if(isset($authUrl)) 
    print "<a class='login' href='$authUrl'>Connect Me!</a>";
   else 
   print "<a class='logout' href='?logout'>Logout</a>";
  
?>
</div>
</body>
</html>

谢谢...

**编辑*** 缺少范围--已添加

 $client->setScopes(array('https://www.googleapis.com/auth/userinfo.email','https://www.googleapis.com/auth/userinfo.profile'));

现在可以使用...

【问题讨论】:

你遇到了什么错误? 我没有收到任何错误,我只是不确定我是否正确使用了对象 [$userinfo = $plus->userinfo;]。在此之后,我如何从 $userinfo 对象访问用户信息。我试过 $userinfo->get() 但只返回 ID 在哪里添加缺少的范围? 创建客户端对象后 $client = Google_OAUTH_Client_Class::getGoogleClient(); $client->setScopes(array(......)); 【参考方案1】:

缺少作用域

$client->setScopes(array('https://www.googleapis.com/auth/userinfo.email','https://www.googleapis.com/auth/userinfo.profile'));

现在就像一个魅力!

【讨论】:

【参考方案2】:

我不确定它是否有帮助,但由于 Google API PHP 客户端已更新,我以这种方式获取用户信息:

        $oauth = new Google_Service_Oauth2($googleClient);

        var_dump($oauth->userinfo->get());

【讨论】:

我曾经使用过这种方法,但是以前的版本是这样做的,而不是现在的版本。【参考方案3】:

Google API PHP client 库已更改 - 以下是获取用户信息的方式:

<?php

require_once('google-api-php-client-1.1.7/src/Google/autoload.php');

const TITLE = 'My amazing app';
const REDIRECT = 'https://example.com/myapp/';

session_start();

$client = new Google_Client();
$client->setApplicationName(TITLE);
$client->setClientId('REPLACE_ME.apps.googleusercontent.com');
$client->setClientSecret('REPLACE_ME');
$client->setRedirectUri(REDIRECT);
$client->setScopes(array(Google_Service_Plus::PLUS_ME));
$plus = new Google_Service_Plus($client);

if (isset($_REQUEST['logout'])) 
        unset($_SESSION['access_token']);


if (isset($_GET['code'])) 
        if (strval($_SESSION['state']) !== strval($_GET['state'])) 
                error_log('The session state did not match.');
                exit(1);
        

        $client->authenticate($_GET['code']);
        $_SESSION['access_token'] = $client->getAccessToken();
        header('Location: ' . REDIRECT);


if (isset($_SESSION['access_token'])) 
        $client->setAccessToken($_SESSION['access_token']);


if ($client->getAccessToken() && !$client->isAccessTokenExpired()) 
        try 
                $me = $plus->people->get('me');
                $body = '<PRE>' . print_r($me, TRUE) . '</PRE>';
         catch (Google_Exception $e) 
                error_log($e);
                $body = htmlspecialchars($e->getMessage());
        
        # the access token may have been updated lazily
        $_SESSION['access_token'] = $client->getAccessToken();
 else 
        $state = mt_rand();
        $client->setState($state);
        $_SESSION['state'] = $state;
        $body = sprintf('<P><A HREF="%s">Login</A></P>',
            $client->createAuthUrl());


?>

<!DOCTYPE HTML>
<HTML>
<HEAD>
        <TITLE><?= TITLE ?></TITLE>
</HEAD>
<BODY>
        <?= $body ?>
        <P><A HREF="<?= REDIRECT ?>?logout">Logout</A></P>
</BODY>
</HTML>

别忘了-

    在Google API console 获取 Web 客户端 ID 和密码 在同一地点授权https://example.com/myapp/

您可以在Youtube GitHub找到官方示例。

2017 年更新:

您可以添加要检索的字段:

const FIELDS       = 'id,name,image';
$me = $plus->people->get('me', array('fields' => FIELDS));

【讨论】:

以上是关于从 Google OAuth 2.0 PHP API 获取用户信息的主要内容,如果未能解决你的问题,请参考以下文章

PHP:Google plus Oauth 2.0 - 获取OAuth2访问令牌时出错,消息:'invalid_client'

Google OAuth 2.0 服务帐户 - 日历 API(PHP 客户端)

使用 Google oAuth 2.0 时新用户登录时刷新页面

适用于 Google Bigquery 的 Oauth 2.0

如何从 Google OAuth 2.0 Playground 运行 Google App Script 功能 |调用者没有权限

OAuth 2.0 PHP客户端和服务器示例