Gmail API:如何获取访问令牌?

时间:2015-06-03 07:09:12

标签: php google-api google-oauth google-api-php-client gmail-api

我正在测试Gmail API

到目前为止,我已完成以下工作:

所以现在当我运行文件quickstart.php时,它会给出一个链接。当我打开它时,它会显示一个授权页面,我授权我的应用程序访问Gmail API。

然后重定向到我在设置中声明的重定向URI (添加代码参数)。

在地址栏中,它显示为:

http://localhost/main/gmail_callback?code=MY_CODE

main 是我的控制器,而 gmail_callback 到目前为止只是一个空白功能。

它应该是正确的,因为这些是我的设置:

  • Javascript起源:http://localhost
  • 重定向URI:http://localhost/main/gmail_callback

下一步该怎么做?

3 个答案:

答案 0 :(得分:2)

流程的下一步是交换访问令牌的授权码(如果您请求离线访问,还将包括刷新令牌)。如果您使用https://developers.google.com/oauthplayground/手动执行流程,则可以查看所涉及的网址。有一个php库调用来做同样的事情,但我个人更喜欢发送自己的HTTP而不是使用库。即使您使用了库,仍然值得花一点时间来理解HTTP流,这样您就可以更轻松地调试遇到的任何问题。

答案 1 :(得分:1)

基本上我错了。遵循这些说明就足以获得令牌:

https://developers.google.com/gmail/api/quickstart/php

重点是从命令行而不是从应用程序访问该文件。

答案 2 :(得分:0)

几个月前我制作了一个Oauth Gmail,我得到了类似的东西:

在我的回调函数中:

if (! isset($_GET['code'])) {
  $auth_url = $client->createAuthUrl();
  return $this->redirect($auth_url);
} else {
  $client->authenticate($_GET['code']);
  $_SESSION['access_token'] = $client->getAccessToken();
  $redirect_uri = Router::url('/', true).'Users/gmail';
  return $this->redirect($redirect_uri);
}

在我的gmail()函数中:

public function gmail(){ 
    require APPLIBS.'Google/src/Google'.DS.'autoload.php';
    $client = new Google_Client();
    $client->setAuthConfigFile('../Config/client_secrets.json');
    $client->addScope(Google_Service_Oauth2::PLUS_LOGIN);
    $client->addScope(Google_Service_Oauth2::USERINFO_EMAIL);
    if (isset($_SESSION['access_token']) && $_SESSION['access_token']) {
        $client->setAccessToken($_SESSION['access_token']);
        $oauth_service = new Google_Service_Oauth2($client);
        $data['Profile']['last_name']  = $oauth_service->userinfo->get()->familyName; 
    } 
} 
例如,

$data['Profile']['last_name']包含用户的last_name。