我正在测试Gmail API。
到目前为止,我已经完成了以下操作:
- 我已经在Google开发者控制台 中创建了这个项目
- 我已启用
Gmail API
。 我创建了一个新的
Client ID
和client secret
。在我的PHP脚本中,我已经安装了PHP客户端库并遵循PHP设置说明现在,当我运行文件quickstart。php时,它给出了一个链接。当我打开它时,它出现了一个授权页面,我授权我的应用程序访问Gmail API。
然后它重定向到我在设置中声明的重定向uri(添加code参数)。
在地址栏中显示如下:
http://localhost/main/gmail_callback?代码= MY_CODE
其中main是我的控制器,gmail_callback到目前为止只是一个空白函数。
它应该是正确的,因为这些是我的设置:
- Javascript origin:
http://localhost
- 重定向uri:
http://localhost/main/gmail_callback
下一步该做什么?
流程中的下一步是将授权码交换为访问令牌(如果请求脱机访问,还将包括刷新令牌)。如果您使用https://developers.google.com/oauthplayground/手动执行流,您将能够看到所涉及的url。有一个php库调用来做同样的事情,但我个人更喜欢发送我自己的HTTP而不是使用库。即使使用库,花一点时间理解HTTP流仍然是值得的,这样可以更容易地调试遇到的任何问题。
基本上我的做法是错误的。按照以下说明即可获得令牌:
https://developers.google.com/gmail/api/quickstart/php 关键是要从命令行访问文件,而不是从应用程序。几个月前我做了一个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,例如