想问一个关于第三方登录的问题。
目前在用django + rest framework 搭建一个手机客户端的服务端。
要求可以使用第三方登录,例如微博、qq、微信等。
自定义了User Model,使用手机号码登录,含有昵称等。
rest的认证使用自带的token,没有使用Oauth。
目前的疑惑是,如何将第三方登录的用户,和自定义的User Model结合起来。
多谢。
![]() | 1 virusdefender 2015-08-01 21:11:57 +08:00 第三方第一次登陆的自动创建一个账号 然后要求补全信息 |
2 shiziwen OP @virusdefender 多谢, 但是这种方案不是很适合,因为想让用户第三方登录之后,直接作为登录用户来处理,不用再填写其他信息。 另一方面,我们目前的User Model,使用手机号码作为唯一标示。 现在我的想法是,可能需要修改model的设计,将本站用户和第三方用户分开,但是还没有很好的想法。 |
![]() | 3 virusdefender 2015-08-01 21:47:40 +08:00 @shiziwen 那样的话,估计只能分开了。 |
![]() | 4 delo 2015-08-01 23:29:19 +08:00 via iPhone django可以指定多个auth backend,实现可以去参考python-social相关代码 |
5 dcoder 2015-08-02 02:37:38 +08:00 |
![]() | 6 Reset 2015-08-02 07:27:48 +08:00 via iPhone |
10 shiziwen OP |
12 shiziwen OP |
13 Carrycat 2015-11-12 17:12:35 +08:00 via iPhone drf 自带的 token 是 basic implementation 有很多潜在问题 基本不能实际用 比如 token user 是 onetoone 这个无法做到 single user multiple login 建议你改到 oath2 工具我用的 Django oauth2 toolkit 和 allauth 提供的第三方 social login 再把他们结合一下 |