グーグルのOAuthと地元のdevの
-
18-09-2019 - |
質問
私は、ユーザーの連絡先をインポートするには、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)
所属していません StackOverflow