我正在测试Gmail API。
到目前为止,我已完成以下工作:
Gmail API
。 Client ID
和client secret
。所以现在当我运行文件quickstart.php时,它会给出一个链接。当我打开它时,它会显示一个授权页面,我授权我的应用程序访问Gmail API。
然后重定向到我在设置中声明的重定向URI (添加代码参数)。
在地址栏中,它显示为:
http://localhost/main/gmail_callback?code=MY_CODE
main 是我的控制器,而 gmail_callback 到目前为止只是一个空白功能。
它应该是正确的,因为这些是我的设置:
http://localhost
http://localhost/main/gmail_callback
下一步该怎么做?
答案 0 :(得分:2)
流程的下一步是交换访问令牌的授权码(如果您请求离线访问,还将包括刷新令牌)。如果您使用https://developers.google.com/oauthplayground/手动执行流程,则可以查看所涉及的网址。有一个php库调用来做同样的事情,但我个人更喜欢发送自己的HTTP而不是使用库。即使您使用了库,仍然值得花一点时间来理解HTTP流,这样您就可以更轻松地调试遇到的任何问题。
答案 1 :(得分:1)
答案 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。