python網(wǎng)站第三方登錄,social-auth-app-django模塊,
social-auth-app-django模塊是專門用于Django的第三方登錄OAuth2協(xié)議模塊
目前流行的第三方登錄都采用了OAuth2協(xié)議
安裝
pip install social-auth-app-django
依賴關(guān)系
PyJWT-1.5.3
certifi-2017.7.27.1
chardet-3.0.4
defusedxml-0.5.0
idna-2.6
oauthlib-2.0.4
python3-openid-3.1.0
requests-2.18.4
requests-oauthlib-0.8.0
six-1.11.0
social-auth-app-django-1.2.0
social-auth-core-1.4.0
urllib3-1.22
** 使用文檔 http://coding.imooc.com/lesson/131.html#mid=7393**
使用配置
1.將social_django添加到app配置,settings.py
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app1',
**'social_django',
]
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 配置數(shù)據(jù)庫引擎名稱
'NAME': 'jxiou', # 數(shù)據(jù)庫名稱
'USER': 'test_user', # 數(shù)據(jù)庫用戶名
'PASSWORD': 'test_user', # 數(shù)據(jù)庫密碼
'HOST': '127.0.0.1', # 數(shù)據(jù)庫鏈接地址,為服務器ip
'PORT': '3306', # 數(shù)據(jù)庫端口
}
}
2,輸入命令migrate來生成第三方登錄需要的表

3.配置需要的第三方登錄模塊,settings.py
第三方登錄模塊放在social_core插件下的backends目錄,里面有很多第三方登錄模塊,比如,微信,微博,QQ等

# 設(shè)置要使用的第三方登錄
AUTHENTICATION_BACKENDS = (
**'social_core.backends.weixin.WeixinOAuth2', # 使用微信登錄
**'social_core.backends.qq.QQOAuth2', # 使用QQ登錄
'django.contrib.auth.backends.ModelBackend', # 指定django的ModelBackend類
)
4.配置第三方登錄路由url
from django.conf.urls import url, include # 導入django自在的include邏輯
from django.contrib import admin
from app1.views import alipaview
urlpatterns = [
url(r'^admin/', admin.site.urls),
# 支付寶返回url
url(r'^alipa/', alipaview, name='alipa'),
# 第三方登錄
**url('', include('social_django.urls', namespace='social'))
]
5.配置 TEMPLATES,settings.py
配置這里,當用戶登錄的時候,如果用戶不存在,會自動在用戶表創(chuàng)建用戶,并且關(guān)聯(lián)用戶信息
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, 'templates')]
,
'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',
],
},
},
]
使用第三方配置
# 設(shè)置要使用的第三方登錄
AUTHENTICATION_BACKENDS = (
'social_core.backends.weibo.WeiboOAuth2', # 使用微博登錄
'social_core.backends.weixin.WeixinOAuth2', # 使用微信登錄
'social_core.backends.qq.QQOAuth2', # 使用QQ登錄
'django.contrib.auth.backends.ModelBackend', # 指定django的ModelBackend類
)
# 配置微博開放平臺授權(quán)
# SOCIAL_AUTH_要使用登錄模塊的名稱大小_KEY,其他如QQ相同
SOCIAL_AUTH_WEIBO_KEY = '1359594035'
SOCIAL_AUTH_WEIBO_SECRET = '7d33714722f4e5572c116ce2b2433a99'
# 登錄成功后跳轉(zhuǎn)頁面
SOCIAL_AUTH_LOGIN_REDIRECT_URL = '/index/'
配置后,啟動程序,根據(jù)url來構(gòu)造請求地址和,回調(diào)地址
# social_django.urls 源碼中
urlpatterns = [
# authentication / association
# <backend>是一個變量接收要使用登錄模塊的名稱小寫
# 請求URL
url(r'^login/(?P<backend>[^/]+){0}$'.format(extra), views.auth,
name='begin'),
# 回調(diào)URL
url(r'^complete/(?P<backend>[^/]+){0}$'.format(extra), views.complete,
name='complete'),
# disconnection
url(r'^disconnect/(?P<backend>[^/]+){0}$'.format(extra), views.disconnect,
name='disconnect'),
url(r'^disconnect/(?P<backend>[^/]+)/(?P<association_id>\d+){0}$'
.format(extra), views.disconnect, name='disconnect_individual'),
]
請求URL構(gòu)造為:http://域名或者ip/login/使用模塊名稱小寫/
如:http://127.0.0.1:8000/login/weibo/
回調(diào)URL構(gòu)造為:http://域名或者ip/complete/使用模塊名稱小寫/
如:http://127.0.0.1:8000/complete/weibo/
回調(diào)URL一般需要設(shè)置到開放平臺的后臺
前臺頁面可以調(diào)用,請求url
<a href="{% url "social:begin" "weibo" %}">微博登錄</a>
social_auth_usersocialauth 數(shù)據(jù)表里就是管理用戶表的信息
