Google+ получить идентификатор пользователя с помощью электронной почты? - PullRequest
1 голос
/ 06 марта 2012

Я хочу знать, возможно ли получить значение "userId" с помощью API Google+, чтобы отобразить ссылку на определенный профиль пользователя.Для лучшего объяснения у меня есть приложение PHP и есть панель, где я могу просматривать существующих пользователей в моей базе данных.Таким образом, при детализации конкретного пользователя я хочу показать значок Google+, который будет ссылаться на профиль этого пользователя в Google+.У меня нет «userId», но я все еще имею доступ к его адресу электронной почты.Есть предложения?

1 Ответ

1 голос
/ 13 апреля 2012

Нет конечной точки, к которой вы можете обратиться, чтобы преобразовать адрес электронной почты в идентификатор пользователя Google+.

Однако вы можете использовать API REST для определения идентификатора пользователя Google+ текущего пользователя, вошедшего в систему. Для этого пользователю потребуется предоставить вам доступ к своей личности в Google+ через OAuth. Для этого используйте людей, которые получают конечную точку со мной в качестве идентификатора пользователя. Вы можете попробовать это в API Explorer , чтобы посмотреть, как будет выглядеть пользовательский диалог OAuth.

Вот некоторый код, взятый из стартового проекта PHP , который иллюстрирует все, что вам нужно для получения userId текущего пользователя:

if (ini_get('register_globals') === "1") {
 die("register_globals must be turned off before using the starter application");
}

require_once 'google-api-php-client/src/apiClient.php';
require_once 'google-api-php-client/src/contrib/apiPlusService.php';

session_start();

$client = new apiClient();
$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('insert_your_oauth2_client_id');
$client->setClientSecret('insert_your_oauth2_client_secret');
$client->setRedirectUri('insert_your_oauth2_redirect_uri');
$client->setDeveloperKey('insert_your_developer_key');
$client->setScopes(array('https://www.googleapis.com/auth/plus.me'));
$plus = new apiPlusService($client);

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

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

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

if ($client->getAccessToken()) {
  $me = $plus->people->get('me');
  // Do stuff with the id
  echo $me['id'];

  // The access token may have been updated lazily.
  $_SESSION['access_token'] = $client->getAccessToken();
} else {
  $authUrl = $client->createAuthUrl();
}
...