我拼命试图找出我自己的,并不想这个问题来到SO,但我在我的智慧结束(不用感谢api/oauth文档)。谷歌分析API V3/OAuth 2
我正在使用PHP,我试图通过在analytics.data.ga.get
方法中使用REST来避免使用Google_Client
和AnalyticsService
类。
STEP #1: Create an API Project for a Web Application
我去api console,并创建与分析服务项目,并取得OAuth客户端ID和秘密。
我的印象是,我可以为Installed Application或Web Application创建客户端ID,因为我正在手动执行初始令牌握手。如果我错了,请纠正我。
创建Web应用程序的客户端ID,并让我的客户端ID xxxxxxxxxxxxxx.apps.googleusercontent.com
,客户端秘密yyyyyyyyyyyyyyy
,和我的重定向URI是http://localhost:9002
STEP #2: Request initial API access
我进入这个链接; https://accounts.google.com/o/oauth2/auth?response_type=code&client_id=xxxxxxxxxxxxxx.apps.googleusercontent.com&redirect_uri=http://localhost:9002&scope=https://www.googleapis.com/auth/analytics.readonly&access_type=offline
access_type=offline
是因为我正在使用REST,并且不要指望“用户”(我自己)每次需要刷新的令牌时手动处理重定向/弹出窗口。
上述请求返回http://localhost:9002?code=4/KModH0K_xxxxxxxxxxxxxxxxxxx9Iw.gikOaYRDWywTshQV0ieZDArCOX8XdwI
代码4/KModH0K_xxxxxxxxxxxxxxxxxxx9Iw.gikOaYRDWywTshQV0ieZDArCOX8XdwI
是我的权限申请的API令牌。
STEP #3: Request First Token
因为我的公司的IT问题,我被迫使用PHP 5.2.17和我没有访问PHP卷曲,所以我用file_get_contents
和stream_context_create
。
请求第一个标记为PHP file_get_contents()
;
$opts = array(
'http' => array(
'method' => 'POST',
'header' => 'Content-Type: application/x-www-form-urlencoded',
'content' => 'code=4/KModH0K_xxxxxxxxxxxxxxxxxxx9Iw.gikOaYRDWywTshQV0ieZDArCOX8XdwI&client_id=xxxxxxxxxxxxxx.apps.googleusercontent.com&client_secret=yyyyyyyyyyyyyyy&redirect_uri=http://localhost:9002&grant_type=authorization_code'
)
);
$context = stream_context_create($opts);
$result = file_get_contents('https://accounts.google.com/o/oauth2/token', false, $context);
var_dump($result);
内容参数必须在一行中。
上面的代码返回我JSON格式access_token
和refresh_token
string(195) "{ "access_token" : "ya29.AHES6wwwwwwwwwwwwwwwVEBXE6XRbC-Q-pP0wZWdoIm9H804ro", "token_type" : "Bearer", "expires_in" : 3600, "refresh_token" : "1/8tXvdUKcSEcaaxVqqqqqqqqqqqqqoYpj2KSS9qwWI" }"
刷新令牌,我必须在一个安全的地方存放,如DB或受保护的txt文件,这是在当我的access_token叫已超时。
STEP #4: Request Analytics Data
现在从我个人理解,我已经准备好了,应该能够用我的access_token
做出请求https://www.googleapis.com/analytics/v3/data/ga
。
我通过发送这个请求来做到这一点;
$request = 'https://www.googleapis.com/analytics/v3/data/ga' .
'?ids=ga%3Aaaaaaaaa' .
'&start-date=2012-12-07' .
'&end-date=2012-12-09' .
'&metrics=ga%3Avisits';
$opts = array(
'http' => array(
'method' => 'GET',
'header' => 'Content-Type: application/x-www-form-urlencoded\r\n' .
'Authorization: Bearer ya29.AHES6wwwwwwwwwwwwwwwVEBXE6XRbC-Q-pP0wZWdoIm9H804ro \r\n'
)
);
$context = stream_context_create($opts);
$result = file_get_contents($request, FALSE, $context);
var_dump($result);
此请求返回401 Unauthorized
错误。我认为这意味着我的请求已正确组建,并与https://www.googleapis.com/analytics/v3/data/ga
建立连接。
另外,根据这个文档Getting Full Quota,我可以在这样的URL做access_token
的请求;
$request = 'https://www.googleapis.com/analytics/v3/data/ga' .
'?ids=ga%3A48564799' .
'&access_token=ya29.AHES6wwwwwwwwwwwwwwwVEBXE6XRbC-Q-pP0wZWdoIm9H804ro' .
'&start-date=2012-12-07' .
'&end-date=2012-12-09' .
'&metrics=ga%3Avisits';
$result = file_get_contents($request, FALSE);
$result = json_decode($result);
var_dump($result);
这次我接收403 error
,其中谷歌包含响应User does not have sufficient permissions for this profile
。
QUESTION #1
上午我缺少的API控制台的东西或一个过程,令牌获取?我假设我没有,因为我最终获得了access_token=ya29
和刷新令牌。
QUESTION #2
也许我完全是基于假设我可以做到这一点与简单的https请求?我必须使用Google_Client
和AnalyticsService
类吗?我不认为这是事实,但也许我错了。
QUESTION #3
我是否需要在我的请求中使用'key'? &key=bbbbbbbbbbbbbbbb
QUESTION #4
通过使用PHP 5.2.17是我失去了一些东西? (除5.3或5.4之外)
例如,在某些版本的PHP中,在stream_context_create
中,标头应该位于数组中而不是字符串,如下所示;
$opts = array(
'http' => array(
'method' => 'GET',
'header' => array(
'Content-Type: application/x-www-form-urlencoded',
'Authorization: Bearer ya29.AHES6wwwwwwwwwwwwwwwVEBXE6XRbC-Q-pP0wZWdoIm9H804ro '
)
)
);
但我不认为这是我的情况的问题。我只是好奇,如果这些HTTP请求需要形成一个不同的方式(不使用卷曲)。
任何见解和想法将不胜感激
难道你看看403 - 权限不足的错误,并确保联合国/ PW使用的是组合访问到配置文件? –
访问令牌需要刷新1小时才能刷新。您是否使用Refresh令牌获得新的Access令牌? –
@jk我不确定你的用户名和密码组合是什么意思。 'access_token'不代表凭证吗?我没有看到文档中的任何地方(除了可能在使用类时)un/pw是必要的。我绝对没有看到简单的获取请求的任何参数。 – bmorenate