1

我正在使用 oAuth2WebServerFlow 获取 oAuth 访问令牌,然后检索用户联系人列表。我使用 web2py 作为 web 框架。

    flow = oauth2client.client.OAuth2WebServerFlow(client_id=CLIENT_ID,
                                                   client_secret=CLIENT_SECRET,
                                                  scope='https://www.google.com/m8/feeds', 
                                                   user_agent=USER_AGENT)
    callback = 'http://127.0.0.1:8000/Test/searcher/oauth2callback'
    authorise_url = flow.step1_get_authorize_url(callback)
    session.flow = pickle.dumps(flow)
    redirect(authorise_url) 

然后按如下方式处理重定向

flow = pickle.loads(session.flow)
credentials = flow.step2_exchange(request.vars) 

我的问题是如何将上面返回的 OAuth2Credentials 对象更改为 OAuth2AccessToken 对象,然后我可以使用它来授权对联系人库的请求,例如:

gc = gdata.contacts.client.ContactsClient(source="")
token.authorize(gc)
gc.GetContacts

我尝试了各种方法都没有成功,通常会收到“无效授权”的 oAuth2AccessTokenError 消息。我在想这样的事情可能会奏效,但也认为必须有一种更简单的方法!

token = gdata.gauth.OAuth2Token(client_id=CLIENT_ID, client_secret=CLIENT_SECRET, scope='https://www.google.com/m8/feeds', user_agent=USER_AGENT)

    token.redirect_uri = 'http://127.0.0.1:8000/Test/searcher/oauth2callback'
    token.get_access_token(<<code to pass the access_token out of the Credentials object??>>)

有人能帮忙吗?

4

2 回答 2

4

我设法让这个工作。实际上这很简单,我只是停止使用 OAuth2WebServerFlow,无论如何它似乎并没有增加太多价值。所以新代码如下所示:

token = gdata.gauth.OAuth2Token(client_id, client_secret, scope, ua)
session.token = pickle.dumps(token)                   
redirect(token.generate_authorize_url(redirect_uri='http://127.0.0.1:8000/Test/default/oauth2callback'))

其次是

def oauth2callback():
    token = pickle.loads(session.token)
    token.redirect_uri='http://127.0.0.1:8000/Test/default/oauth2callback'
    token.get_access_token(request.vars.code)
    gc = gdata.contacts.client.ContactsClient(source='')
    gc = token.authorize(gc)
    feed = gc.GetContacts()

希望这对某人有帮助!

于 2012-07-08T18:31:02.490 回答
1

假设您正确设置了较新的 OAuth2.0 API 的代码,您可以通过创建一个 Token 类来修改转换 Credentials -> Token 类的标头来实现此功能。

OAUTH_LABEL='OAuth '

#Transforms OAuth2 credentials to OAuth2 token.
class OAuthCred2Token(object):

    def __init__(self, token_string):
        self.token_string = token_string

    def modify_request(self, http_request):
        http_request.headers['Authorization'] = '%s%s' % (OAUTH_LABEL,
                                                          self.token_string)

    ModifyRequest = modify_request

您可以按如下方式对其进行测试:

gc = gdata.contacts.client.ContactsClient(source='')
token = OAuthCred2Token(creds.access_token)
gc.auth_token = token
print gc.GetContacts()

请注意,此代码将不处理令牌刷新,该代码使用凭据处理。在我自己的应用程序中,可以使用服务进行简单调用以在调用获取联系人之前刷新凭据。

于 2013-02-17T08:02:33.560 回答