質問

私は、ユーザーの連絡先をインポートするには、GoogleのOAuthを使用しようとしています。あなたは HTTPSでドメインを確認する必要があるアプリケーションのための消費者と秘密鍵を取得するために:// WWW .google.com /アカウント/ ManageDomainsは、Googleがあなたのポートせずにドメインのみを使用することができますを。私はローカルでアプリケーションをテストし、構築したいので、通常(FacebookやLinkedInのアプリケーション)は、i例えば、ユーザの逆SSHトンネルのhttp:/ /6pna.com:30002する

は、誰もがグーグルのOAuthとのトンネルを使用して持っています。それは動作しますか?これまでのところ私はちょうど私のAppsドメインを検証しますが、私の要求は、トンネル(異なるドメイン)から来るので、OAuthのに失敗した(私はGoogleに取得し、私のアプリを許可するが)

任意のヒント、ヒント?おかげ

役に立ちましたか?

解決

私は、要求のドメインが無関係であることが分かっただけでなく、試行錯誤の後に

他のヒント

私はちょうど公式GDATAのGoogleの認証ライブラリ http://code.googleを使用しています。

のCOM / P / GDATA-のpython-クライアント

ここではいくつかのコードです。

    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)
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top