2

我有一个 django 应用程序,并为移动应用程序创建 API。当涉及到用户身份验证时,我简单地获取登录 + 通过并执行标准的 django 登录内容。当用户登录时,我生成一个令牌,将其保存并提供给移动应用程序。

现在谈到 Facebook,我想实现 python-social-auth 库。我确实知道如何为标准网络实现它,这真的很简单。但我不知道如何将它实现到我的移动 API 以及如何将我的令牌内容合并到那里。

只是在想......是否有可能进行编程身份验证,以便我能够创建 API 方法并从那里调用社交身份验证的东西?但是,Facebook 端的“允许访问 XY 应用程序以访问您的个人资料”页面怎么样?

任何建议都有帮助。先感谢您。

4

1 回答 1

5

文档描述了如何简单地提供access_token身份验证/创建用户。

from django.contrib.auth import login

from social.apps.django_app.utils import psa

# Define an URL entry to point to this view, call it passing the
# access_token parameter like ?access_token=<token>. The URL entry must
# contain the backend, like this:
#
#   url(r'^register-by-token/(?P<backend>[^/]+)/$',
#       'register_by_access_token')

@psa('social:complete')
def register_by_access_token(request, backend):
    # This view expects an access_token GET parameter, if it's needed,
    # request.backend and request.strategy will be loaded with the current
    # backend and strategy.
    token = request.GET.get('access_token')
    user = request.backend.do_auth(request.GET.get('access_token'))
    if user:
        login(request, user)
        return 'OK'
    else:
        return 'ERROR'
于 2015-03-09T16:15:41.803 回答