Google 驱动 OAuth2 - 对回调和重定向 URI 感到困惑

Google Drive OAuth2 - confused about callback and redirect URI

场景非常简单。正在开发一个网络应用程序,它将允许用户访问他们的 Google 驱动器到 save/read 个文件。

使用 Google 中的 PHP 快速入门示例,我能够让它工作,从而它从 Google 生成的 JSON 文件中读取客户端机密信息,打印请求者 URL,将其复制粘贴到浏览器中,这将调用 Google 权限页面,然后我们将 code 重定向到 http://localhost 作为 GET 参数。 Copy/past 将 code 放入快速入门演示应用程序中,它可以正常工作。

但是,用户体验,尤其是 tablet/phone 的用户体验非常糟糕。

我希望能够重定向到保存代码的服务器,然后调用用户 Web 应用程序会话可以轮询此服务器(使用额外的安全凭证)以获取代码。

我无法理解的是如何获取 Google 使用访问代码调用的 callback/redirect URI,以包含我们的调用 Web 应用程序提供的附加标识符,以便它可以识别在我们有多个用户同时请求代码的情况下 Google 的正确响应。

您可以使用Google OAuth2 for Server-side Web Apps中所示的结构。它可以帮助您在不使用代码策略的情况下处理身份验证流程。

main point 是用访问令牌交换授权令牌:

$client->authenticate($_GET[‘code’])
// Using getAccesToken method
$access_token = $client->getAccessToken();

可以参考PHP的例子

index.php
<?php
require_once __DIR__.'/vendor/autoload.php';

session_start();

$client = new Google_Client();
$client->setAuthConfig('client_secrets.json');
$client->addScope(Google_Service_Drive::DRIVE_METADATA_READONLY);

if (isset($_SESSION['access_token']) && $_SESSION['access_token']) {
  $client->setAccessToken($_SESSION['access_token']);
  $drive = new Google_Service_Drive($client);
  $files = $drive->files->listFiles(array())->getItems();
  echo json_encode($files);
} else {
  $redirect_uri = 'http://' . $_SERVER['HTTP_HOST'] . '/oauth2callback.php';
  header('Location: ' . filter_var($redirect_uri, FILTER_SANITIZE_URL));
}
oauth2callback.php
<?php
require_once __DIR__.'/vendor/autoload.php';

session_start();

$client = new Google_Client();
$client->setAuthConfigFile('client_secrets.json');
$client->setRedirectUri('http://' . $_SERVER['HTTP_HOST'] . '/oauth2callback.php');
$client->addScope(Google_Service_Drive::DRIVE_METADATA_READONLY);

if (! isset($_GET['code'])) {
  $auth_url = $client->createAuthUrl();
  header('Location: ' . filter_var($auth_url, FILTER_SANITIZE_URL));
} else {
  $client->authenticate($_GET['code']);
  $_SESSION['access_token'] = $client->getAccessToken();
  $redirect_uri = 'http://' . $_SERVER['HTTP_HOST'] . '/';
  header('Location: ' . filter_var($redirect_uri, FILTER_SANITIZE_URL));
}