2

我正在使用 Twython 为使用 Django 构建的网站实现 OAuth 功能。我希望用户能够使用他们的 Twitter 凭据进行注册和登录。

通过稍微调整 Twython Git 存储库中的示例,我创建了用于登录和注册 twitter 信息的基本视图。

我的问题是用户目前可以在 Firefox 和 Chrome 中使用 Twitter OAuth 注册,但不能在 Safari 中注册。我实现此功能的观点是:

def begin_auth(request):
        twitter = Twython(
        twitter_token = TWITTER_KEY,
        twitter_secret = TWITTER_SECRET,
        callback_url = request.build_absolute_uri(reverse('portnoy.views.thanks'))
    )
    # Request an authorization url to send the user to...
    auth_props = twitter.get_authentication_tokens()

    # Then send them over there, durh.
    request.session['request_token'] = auth_props
    return HttpResponseRedirect(auth_props['auth_url'])

def thanks(request, redirect_url='/'):
     c = RequestContext(request)
     twitter = Twython(
         twitter_token = TWITTER_KEY,
         twitter_secret = TWITTER_SECRET,
         oauth_token = request.session['request_token']['oauth_token'],
         oauth_token_secret = request.session['request_token']['oauth_token_secret']
     )

    # Retrieve the tokens we want...
    authorized_tokens = twitter.get_authorized_tokens()
    request.session['request_tokens'] = authorized_tokens
    debug('thanks', request.session['request_tokens'])

    user = User.objects.filter(username=authorized_tokens['screen_name'])
    if user.exists():
        user = user[0]
        user.backend='django.contrib.auth.backends.ModelBackend'     
        auth.login(request,user)
    else:
        return render_to_response('twitter_register.html', c)   
    return HttpResponseRedirect(redirect_url)

在第二个视图中,谢谢,我获取了 authorized_tokens 并将它们存储在会话中,因此它们可以在未注册用户指向的 twitter_register.html 页面中轻松访问,从而允许未注册用户使用他们的 Twitter 信息进行注册。

下面提供了 Safari 中直到失败行的 twitter_register 视图代码:

def twitter_register(request):
    c = RequestContext(request)
    if request.method == 'POST':
        email = request.POST.get('email')
    password = request.POST.get('password')
    if not SafeContact.objects.filter(email=email).exists():
        return HttpResponseRedirect('/')
    if (User.objects.filter(email=email).exists()):
        c['warning'] = "Looks like that email is already in use"
        return render_to_response('twitter_register.html', c) 
    #debug('twitter_register', request.session['request_tokens'])
    twitter = Twython(
        twitter_token = TWITTER_KEY,
        twitter_secret = TWITTER_SECRET,
        oauth_token = request.session['request_tokens']['oauth_token'],
        oauth_token_secret = request.session['request_tokens']['oauth_token_secret']
    )
    debug('twitter_register', request.session['request_tokens'])
    twitter_user_dict = twitter.showUser(screen_name=request.session['request_tokens']['screen_name'])

所有这些都适用于 Firefox 和 Chrome,但在 Safari 中失败。特别是,在 Safari 中,此代码在 twitter_register 的最后提供的行中失败:

twitter.showUser(screen_name=request.session['request_tokens']['screen_name']). 

产生以下错误:

The error is KeyError: 'screen_name'.

调试语句 debug('thanks', request.session['request_tokens']) 在 Firefox 和 Chrome 中按预期打印了 authorized_tokens,但由于某种原因在 Safari 中打印了 2x。第一次打印时,它按预期显示授权令牌的字典,但在第二次打印时,它显示

thanks: {'<?xml version': '"1.0" encoding="UTF-8"?>\\n<hash>\\n  <error>Invalid / expired Token</error>\\n  <request>/oauth/access_token</request>\\n</hash>\\n'}

我很困惑,因为这似乎只发生在 Safari 中(我正在测试 v. 5.1.5)。

任何有关如何解决此问题的建议将不胜感激。感谢您花时间看这个!

4

1 回答 1

0

“谢谢”视图似乎被执行了两次。

您的 twitter_register 视图中的以下几行是否可能导致它?

if not SafeContact.objects.filter(email=email).exists():
        return HttpResponseRedirect('/')
于 2012-11-14T21:45:45.283 回答