Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >当通过api提供访问令牌时,如何创建新用户和新的django allauth社交帐户?

当通过api提供访问令牌时,如何创建新用户和新的django allauth社交帐户?
EN

Stack Overflow用户
提问于 2013-05-05 05:37:38
回答 3查看 3.5K关注 0票数 9

我有一个移动应用程序,允许用户通过Facebook注册。一旦我从FB收到访问令牌,我就把它发送到Django后端。

但是然后呢?

django-allauth中有没有一种方法,我可以将访问令牌提供给它,让它创建新的用户/社交帐户?

或者我需要手动完成所有这些操作?

EN

回答 3

Stack Overflow用户

发布于 2013-05-05 07:14:27

我似乎总是在我贴出问题之后就能找到答案。在任何情况下,以下都是UserResource (使用ApiKeyAuthentication的品味api )上的自定义方法。其中大部分代码取自allauth.socialaccount.providers.facebook.views.中的login_by_token方法

我暂时不会选择正确的答案,以防有人发布更好的答案。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def facebook_login(self, request, **kwargs):
    self.method_check(request, allowed=['post'])

    data = self.deserialize(request, request.raw_post_data, format=request.META.get('CONTENT_TYPE', 'application/json'))

    access_token = data.get('access_token', '')

    from allauth.socialaccount import providers
    from allauth.socialaccount.models import SocialLogin, SocialToken, SocialApp
    from allauth.socialaccount.providers.facebook.views import fb_complete_login
    from allauth.socialaccount.helpers import complete_social_login
    try:
        app = SocialApp.objects.get(provider="facebook")
        token = SocialToken(app=app,
                            token=access_token)
        login = fb_complete_login(app, token)
        login.token = token
        login.state = SocialLogin.state_from_request(request)
        ret = complete_social_login(request, login)

        #if we get here we've succeeded
        return self.create_response(request, {
                'success': True,
                'username': request.user.username,
                'user_id': request.user.pk,
                'api_key': request.user.api_key.key,
                } ) 
    except:
        # FIXME: Catch only what is needed
        return self.create_response(request, {
                'success': False,
                'reason': "Bad Access Token",
                }, HttpForbidden ) 
票数 7
EN

Stack Overflow用户

发布于 2017-03-16 21:49:32

现代读者(2017)可能想看看django-rest-auth,它构建在allauth之上,但在构建时考虑到了单页面应用程序:

http://django-rest-auth.readthedocs.io/en/latest/introduction.html

票数 2
EN

Stack Overflow用户

发布于 2013-06-27 03:09:48

工作源代码:在类UserResource(ModelResource)中:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def override_urls(self):
    return [
        url(r"^(?P<resource_name>%s)/facebook_login%s$" %
            (self._meta.resource_name, trailing_slash()),
            self.wrap_view('facebook_login'), name="api_facebook_login"),
    ]

def facebook_login(self, request, **kwargs):
    self.method_check(request, allowed=['post'])

    data = self.deserialize(
        request,
        request.raw_post_data,
        format=request.META.get('CONTENT_TYPE', 'applicaton/json'))

    access_token = data.get('access_token', '')

    print(access_token)

    from allauth.socialaccount import providers
    from allauth.socialaccount.models import SocialLogin, SocialToken, SocialApp
    from allauth.socialaccount.providers.facebook.views import fb_complete_login
    from allauth.socialaccount.helpers import complete_social_login
    try:
        app = SocialApp.objects.get(provider="facebook")
        print(app)
        token = SocialToken(app=app,
                            token=access_token)
        login = fb_complete_login(app, token)
        login.token = token

        login.state = SocialLogin.state_from_request(request)
        ret = complete_social_login(request, login)

        #if we get here we've succeeded
        return self.create_response(request, {
                'success': True,
                'username': request.user.username,
                'user_id': request.user.pk,
                'api_key': request.user.api_key.key,
                } )
    except:
        # FIXME: Catch only what is needed
        return self.create_response(request, {
                'success': False,
                'reason': "Bad Access Token",
                }, HttpForbidden )

然后:

curl --dump-header - -H“内容类型:应用程序/json”-X POST --data '{"access_token":"xxxxxxxx"}‘http://xx.xxxxxx.com:8000/api/v1/user/facebook_login/

测试正常,创建用户正常。

谢谢。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16381732

复制
相关文章
六种Web身份验证方法比较和Flask示例代码
在本文中,我们将从Python Web开发人员的角度看处理Web身份验证的最常用方法。
小锋学长生活大爆炸
2022/05/14
7.5K0
六种Web身份验证方法比较和Flask示例代码
【Django | allauth】重写allauth重置密码方法
allauth中的重置密码的类视图位于allauth.account.views.PasswordResetView,我们需要在views.py中继承这个类并且重写它的post方法。
计算机魔术师
2022/08/16
1.4K0
通过GiHub 查找 API 密钥、令牌和密码
关键词: Passwords api_key “api keys” authorization_bearer: oauth auth authentication client_secret api_token: “api token” client_id password user_password user_pass passcode client_secret secret password hash OTP user auth
Khan安全团队
2022/05/17
1.1K0
通过GiHub 查找 API 密钥、令牌和密码
使用django-allauth管理用户登录与注册
 django-allauth 是非常受欢迎的管理用户登录与注册的第三方 Django 安装包,django-allauth 集成了 local 用户系统 和 social 用户系统,其 social 用户系统 可以挂载多个账户。 django-allauth 能实现以下核心功能:
菲宇
2019/06/13
6.9K0
Django开发常用30个软件包
Django是一款高级的Python Web框架,可以帮助开发者快速创建web应用。我们这里整理了30款Django开发中常用的软件包,学会使用它们可以节省大量开发时间,提高开发效率。下面一起来看下。   认证和授权  1. Python social auth 一款社交账号认证/注册机制,支持Django、Flask、Webpy等在内的多个开发框架,提供了约50多个服务商的授权认证支持,如Google、Twitter、新浪微博等站点,配置简单。
菲宇
2022/12/21
3.4K0
如何创建MySQL用户帐户和授予权限
MySQL是最流行的开源关系数据库管理系统。 MySQL服务器允许我们创建大量用户帐户并授予适当的权限,以便用户可以访问和管理数据库。
星哥玩云
2022/08/18
2.6K0
如何创建MySQL用户帐户和授予权限
【Django | allauth】登录_注册_邮箱验证_密码邮箱重置
如果觉得邮箱提示地址 example.com 名字太丑,还可以在admin 中修改 display\_name
计算机魔术师
2022/08/16
3.9K0
简化 Django 开发的八个 Python 包 | Linux 中国
这个月的 Python 专栏将介绍一些 Django 包,它们有益于你的工作,以及你的个人或业余项目。-- Jeff Triplett
用户7886150
2020/12/30
3K0
[博客搭建] 通过用户邮箱认证来介绍 django-allauth 的使用思路
我的博客使用了 django-allauth 应用插件,所以是支持 Oauth2.0 协议的第三方账号登录(Github 和 Weibo)。同时,博客支持邮箱注册登录,不过我之前关闭了邮箱认证,现在已经开启验证功能,用户注册和登录之后都可以选择是否进行认证,当然,认证的用户肯定会有特权,至于什么特权,请看本文介绍。
Hopetree
2022/09/26
6250
[博客搭建]  通过用户邮箱认证来介绍 django-allauth 的使用思路
授权服务是如何颁发授权码和访问令牌的?
授权服务如何生成访问令牌? 访问令牌过期了而用户又不在场的情况下,又如何重新生成访问令牌?
JavaEdge
2021/02/23
2.8K0
授权服务是如何颁发授权码和访问令牌的?
Django教程(一)- Django视图与网址1.简介2.环境搭建3.安装pycharm4.Ubuntu下 正确安装VMware Tools5.Django主要模块6.Django基本命令7. Dj
Django 是用Python开发的一个免费开源的Web框架,可以用于快速搭建高性能,优雅的网站!
Python攻城狮
2018/08/23
1.4K0
Django教程(一)- Django视图与网址1.简介2.环境搭建3.安装pycharm4.Ubuntu下 正确安装VMware Tools5.Django主要模块6.Django基本命令7. Dj
【Django | allauth】useprofile 用户模型扩展
在allauth 包中复制粘贴templates 的account包到该项目的templates的account下,原因:
计算机魔术师
2022/08/16
1.1K0
15款Django开发常用软件包 原
1. Python social auth 一款社交账号认证/注册机制,支持Django、Flask、Webpy等在内的多个开发框架,提供了约50多个服务商的授权认证支持,如Google、Twitter、新浪微博等站点,配置简单。  
晓歌
2018/08/15
2.1K0
访问令牌JWT
By reference token(透明令牌),随机生成的字符串标识符,无法简单猜测授权服务器如何颁 发和存储资源服务器必须通过后端渠道,发送回OAuth2授权服务器的令牌检查端点,才能校验令牌 是否有效,并获取claims/scopes等额外信息
乐心湖
2020/08/02
1.7K0
关于Web验证的几种方法
验证(Authentication)是具备权限的系统验证尝试访问系统的用户或设备所用凭据的过程。相比之下,授权(Authorization)是给定系统验证是否允许用户或设备在系统上执行某些任务的过程。 简单地说: 身份验证:你是谁? 授权:你能做什么? 身份验证先于授权。也就是说,用户必须先处于合法状态,然后才能根据其授权级别被授予对资源的访问权限。验证用户身份的最常见方法是用户名和密码的组合。用户通过身份验证后,系统将为他们分配不同的角色,例如管理员、主持人等,从而为他们授予一些特殊的系统权限。 接下来,我们来看一下用于用户身份验证的各种方法。
程序狗
2021/12/09
3.9K0
访问令牌过期后,如何自动续期?
JWT是JSON Web Token的缩写,是为了在网络应用环境间传递声明而执行的- -种基于JSON的开放标准((RFC 7519)。JWT本身没有定义任何技术实现,它只是定义了一种基于Token的会话管理的规则,涵盖Token需要包含的标准内容和Token的生成过程,特别适用于分布式站点的单点登录(SSO) 场景。
Tinywan
2023/03/08
2.7K0
访问令牌过期后,如何自动续期?
【壹刊】Azure AD B2C(一)初识
  上一节讲到Azure AD的一些基础概念,以及如何运用 Azure AD 包含API资源,Azure AD 是微软提供的云端的身份标识和资源访问服务,帮助员工/用户/管理员访问一些外部资源和内部资源:
老张的哲学
2022/04/11
2.3K0
【壹刊】Azure AD B2C(一)初识
GIF动图只能用做表情包?黑客拿来入侵微软视频会议软件
说到GIF动图,大家可能第一反应是手机微信里那各式各样的表情包了,用表情包斗图是现在人们的一种沟通方式。然而,GIF动图到了黑客手里,就不仅是一种“沟通方式”了。
FB客服
2020/05/04
1.6K0
OAuth 2.0身份验证
浏览网络时,几乎可以肯定您会遇到一些使您可以使用社交媒体帐户登录的网站,该功能很可能是使用流行的OAuth 2.0框架构建的,OAuth 2.0对于攻击者来说非常有趣,因为它非常常见,而且天生就容易出现实现错误,这可能导致许多漏洞,从而使攻击者可以获得敏感用户数据,并有可能绕过身份验证。
Al1ex
2021/04/22
3.5K0
OAuth 2.0身份验证
动态令牌_创建安全令牌
HMAC-based One-Time Password 简写,表示基于 HMAC 算法加密的一次性密码。是事件同步,通过某一特定的事件次序及相同的种子值作为输入,通过 HASH 算法运算出一致的密码。
全栈程序员站长
2022/11/17
1.5K0
动态令牌_创建安全令牌

相似问题

如何创建用于测试的django-allauth常规和社交帐户?

10

Django-Allauth :帐户创建视图上没有社交按钮?

13

django-allauth社交帐户已存在

10

如何在django管理员中隐藏/注销django-allauth创建的帐户和社交帐户?

222

django-allauth社交帐户在登录时连接到现有帐户

32
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文