4

我正在尝试使用 Google OAuth 导入用户的联系人。为了获得您的应用程序的消费者和密钥,您必须在https://www.google.com/accounts/ManageDomains验证您的域Google 允许您仅使用没有端口的域。我想在本地测试和构建应用程序,所以通常(Facebook、Linkedin 应用程序)我使用反向 SSH 隧道,例如http://6pna.com:30002

有没有人使用 Google OAuth 的隧道。它有效吗?到目前为止,我刚刚验证了我的应用程序域,但我的请求来自隧道(不同的域),因此 OAuth 失败(尽管我访问了 Google 并授权了我的应用程序)

任何提示,提示?谢谢

4

2 回答 2

4

经过反复试验,我发现请求的域无关紧要

于 2010-03-10T16:02:58.270 回答
3

我只是使用官方 gdata google auth 库http://code.google.com/p/gdata-python-client

这是一些代码

    google_auth_url = None
    if not current_user.gmail_authorized:
        google = gdata.contacts.service.ContactsService(source=GOOGLE_OAUTH_SETTINGS['APP_NAME'])
        google.SetOAuthInputParameters(GOOGLE_OAUTH_SETTINGS['SIG_METHOD'], GOOGLE_OAUTH_SETTINGS['CONSUMER_KEY'],
                                      consumer_secret=GOOGLE_OAUTH_SETTINGS['CONSUMER_SECRET'])
        if not request.vars.oauth_verifier:
            req_token = google.FetchOAuthRequestToken(scopes=GOOGLE_OAUTH_SETTINGS['SCOPES'],
                          oauth_callback="http://"+request.env.http_host+URL(r=request,c='default',f='import_accounts'))
            session['oauth_token_secret'] = req_token.secret
            google_auth_url = google.GenerateOAuthAuthorizationURL()
        else:
            oauth_token = gdata.auth.OAuthTokenFromUrl(request.env.request_uri)
            if oauth_token:
                oauth_token.secret = session['oauth_token_secret']
                oauth_token.oauth_input_params = google.GetOAuthInputParameters()
                google.SetOAuthToken(oauth_token)
                access_token = google.UpgradeToOAuthAccessToken(oauth_verifier=request.vars.oauth_verifier)
                # store access_tonen

        #google.GetContactsFeed() # do the process or do it in ajax (but first update the user)
于 2010-03-12T13:07:44.037 回答