Google Reader API 简介

Google Reader是我最喜欢的web服务,可惜在iPhone上没有一个我理想中的客户端,所以只好自己动手丰衣足食了。

而开发的第一步自然就是搞定Google Reader API,可惜Google一直没有放出官方文档。所幸的是前人已经通过反向工程探寻出了相关信息(GoogleReaderAPIUsing the Google Reader APIGReader-Cocoa等),所以不用自己去一一摸索了。

不过文档有点老了,这期间Google也稍微改了一些东西,所以还需要稍作修正。

由于现在手头上没有Mac,所以就不用Objective-C,而拿Python来演示。这样代码量也会少很多,逻辑显得更加清晰。

在访问之前需要证明你的身份,所以先去https://www.google.com/accounts/ClientLogin获取登录凭证。

此处需要POST 3个字段:service为'reader',Email为Google账号,Passwd为密码。此外还可以附加source字段用于标明你的客户端,其中网页版是'scroll',iOS网页版是'mobilescroll',你可以随意改成其他字符串。

from urllib import urlencode
from urllib2 import urlopen, Request

LOGIN_URL = 'https://www.google.com/accounts/ClientLogin'
EMAIL = '你的邮箱'
PASSWORD = '你的密码'

request = Request(LOGIN_URL, urlencode({
    'service': 'reader',
    'Email': EMAIL,
    'Passwd': PASSWORD,
    'source': 'mobilescroll'
}))

f = urlopen(request)

然后会拿到这样一串字符串,一共3行:

SID=...
LSID=...
Auth=...

这里我们需要SID和Auth,它们应该是不会过期的,除非退出登录:

lines = f.read().split()
sid = lines[0]
auth = lines[2][5:]

拿到这2个字段后就可以使用Google Reader API了。具体方法就是访问API地址(见GoogleReaderAPI文档),然后把SID作为cookie,Auth作为Authorization。
例如获取订阅列表:

headers = {'Authorization': 'GoogleLogin auth=' + auth, 'Cookie': sid}
request = Request('https://www.google.com/reader/api/0/subscription/list?output=json', headers=headers)
f = urlopen(request)
print f.read()

就会拿到如下的信息:

{"subscriptions":[{"id":"feed/供稿地址","title":"供稿名","categories":[{"id":"user/Google Reader用户ID/label/分类名","label":"分类名"}],"sortid":"不知道啥玩意","firstitemmsec":"第一个条目的时间戳","htmlUrl":"供稿的网站地址"},...(其他供稿的信息)]}

不过如果要修改的话(一般是POST请求),还需要一个token参数。这个token与SID和Auth不同,它很容易过期。因此如果失效了,需要再次请求一个。
请求的地址是http[s]://www.google.com/reader/api/0/token,它可以附带2个可选的GET参数:ck是时间戳,client是客户端名称。

request = Request('https://www.google.com/reader/api/0/token', headers=headers)
f = urlopen(request)
token = f.read()

拿到token后就可以进行订阅等操作了,例如订阅本站:

request = Request('https://www.google.com/reader/api/0/subscription/quickadd?output=json', urlencode({
    'quickadd': 'http://www.keakon.net/feed',
    'T': token
}), headers=headers)
f = urlopen(request)
print f.read()

会拿到这样的结果:

{"query":"http://www.keakon.net/feed","numResults":1,"streamId":"feed/http://www.keakon.net/feed"}

再去看看你的Google Reader,应该就订阅好本站了。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。