当前位置: 移动技术网 > IT编程>脚本编程>Python > OAuth2.0 social_django微博第三方登录

OAuth2.0 social_django微博第三方登录

2019年01月08日  | 移动技术网IT编程  | 我要评论

超级点卡屋,小麦进城全集下载,连云港二手房

python网站第三方登录,social-auth-app-django模块,

social-auth-app-django模块是专门用于django的第三方登录oauth2协议模块

目前流行的第三方登录都采用了oauth2协议

 

安装:

 

pip install social-auth-app-django

 

 

settings.py配置:

installed_apps = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    

    #第三方登录
    'social_django',
]

 

 

 

下一步我们就要执行迁移:

 

python manage.py migrate

 

social开头的就是我们生成的第三方表!

 

然后我们继续settings.py配置:

配置这里,当用户登录的时候,如果用户不存在,会自动在用户表创建用户,并且关联用户信息

 

 

templates = [
{
'backend': 'django.template.backends.django.djangotemplates',
'dirs': [],
'app_dirs': true,
'options': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',

#第三方登录
'social_django.context_processors.backends',
'social_django.context_processors.login_redirect',
],
},
},
]

 

#在配置文件中告知django使用我们自定义的认证后端
authentication_backends = [
    'users.utils.usernamemodelbackend',
'social_core.backends.weibo.weibooauth2', #微博 'django.contrib.auth.backends.modelbackend', #指定django的modelbackend 类
]

 

第三方参数配置:

# 用户key
social_auth_weibo_key = ''
# 用户secret social_auth_weibo_secret = ''
# 登陆后用户跳转的地址 social_auth_login_redirect_url = 'http://127.0.0.1:8080/'

配置主路由:

urlpatterns = [
    url('^xadmin/', xadmin.site.urls),
  

    # 第三方登录
    url('', include('social_django.urls')),
]

下面我们还要配置回调url:

在自己应用里的高级信息里,编辑授权回调页http://127.0.0.1:8000/complete/weibo/,黄色箭头指向的可以不填写

 

最后登录测试一下,看自己social_auth_usersocialauth表里是否有用户

登录成功跳到首页,发现还处于未登录状态,我们需要对源码做修改

我们要找到环境里的social_core目录下的actions.py

然后在100行左右  把下面这行代码

return backend.strategy.redirect(url)

修改为:

from rest_framework_jwt.serializers import jwt_encode_handler,jwt_payload_handler


response = backend.strategy.redirect(url) payload = jwt_payload_handler(user) response.set_cookie("name", user.username if user.username else user.username, max_age=24 * 3600) response.set_cookie("token", jwt_encode_handler(payload), max_age=24 * 3600) return response

修改好后登录之后就可以显示用户了!

 

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网