AuthSub和Blogger

时间:2010-07-15 21:37:48

标签: php curl blogger authsub

我正在尝试检索给定用户的博客列表。 我想我已经连续授权自己使用所有令牌,但是当我要求列表博客时,我收到了302暂时移动。 我正在使用curl发送请求。

在我的回调页面中,我将令牌升级为会话令牌:

$header = array();
$header[] = 'GET /accounts/AuthSubSessionToken HTTP/1.1';
$header[] = 'Authorization: AuthSub token="'.$_GET['token'].'"';

$curl = curl_init('https://www.google.com/accounts/AuthSubSessionToken');
curl_setopt( $curl, CURLOPT_HTTPHEADER, $header );
curl_setopt( $curl, CURLOPT_HEADER, true );
curl_setopt( $curl, CURLOPT_RETURNTRANSFER, true );
curl_setopt( $curl, CURLOPT_SSL_VERIFYPEER, false );
$response = curl_exec( $curl );

我得到了这个回复:

HTTP/1.1 200 OK
Content-Type: text/plain; charset=UTF-8
Date: Thu, 15 Jul 2010 20:08:07 GMT
Expires: Thu, 15 Jul 2010 20:08:07 GMT
Cache-Control: private, max-age=0
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Content-Length: 39
Server: GSE

好的,现在我觉得我已经准备好进行数据检索了,我这样做了:

$headers = array();
$headers[] = 'GET /feeds/default/blogs HTTP/1.1';
$headers[] = 'Authorization: AuthSub token="'.$token.'"';
$headers[] = 'Host: www.blogger.com';

$curl = curl_init( 'http://www.blogger.com' );
curl_setopt( $curl, CURLOPT_CONNECTTIMEOUT, 5 );
curl_setopt( $curl, CURLOPT_TIMEOUT, 5 );
curl_setopt( $curl, CURLOPT_PORT, 80 );
curl_setopt( $curl, CURLOPT_HEADER, true );
curl_setopt( $curl, CURLOPT_HTTPHEADER, $headers );
curl_setopt( $curl, CURLOPT_RETURNTRANSFER, true );
curl_setopt( $curl, CURLOPT_SSL_VERIFYHOST, false );
curl_setopt( $curl, CURLOPT_SSL_VERIFYPEER, false );
curl_setopt( $curl, CURLOPT_FOLLOWLOCATION, true );
curl_setopt( $curl, CURLOPT_MAXREDIRS, 5);
$reply = curl_exec( $curl );

但我总是收到302临时移动。 我已经检查过我没有启用safe_mode也没有openbasedir来允许CURLOPT_FOLLOWLOCATION工作,我还检查了

curl_getinfo( $curl, CURLINFO_EFFECTIVE_URL );

要求确保curl尝试重定向的最后一个网址是什么。

也许我做了一些AuthSub步错了?

PD:显然我省略了提取会话令牌的代码,但我仔细检查了它并抓住了标题的正确部分。

1 个答案:

答案 0 :(得分:1)

如果您检查curl_getinfo($curl);的输出,是否会获得redirect_count?如果是这样的话:如果是5,我会将maxredirs设置得更高。

如果没有,我会设置

curl_setopt($curl,CURLOPT_VERBOSE,true);
curl_setopt($curl,CURLOPT_STDERR, STDOUT)

...并检查它的输出。

也许它就像设置它一样简单(从未使用过博客界面):

curl_setopt($curl,CURLOPT_UNRESTRICTED_AUTH,true);