首页 > 解决方案 > 向 Django 添加社交身份验证

问题描述

我正在使用 Django 3.0.5 和 python 3.6。我想为我的博客添加社交身份验证。相关文件Settings.py、urls.py和login.html分别为:

设置.py:

import os
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
TEMPLATES_DIR=os.path.join(BASE_DIR,'templates')
DEBUG = True
ALLOWED_HOSTS = []
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'blog',
    'social_django',
]

AUTHENTICATION_BACKENDS = [
    'social_core.backends.github.GithubOAuth2',
    'social_core.backends.google.GoogleOAuth2',
    'django.contrib.auth.backends.ModelBackend',

]

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
    'social_django.middleware.SocialAuthExceptionMiddleware',

]

ROOT_URLCONF = 'mysite.urls'

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [TEMPLATES_DIR],
        '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',
            ],
        },
    },
]

WSGI_APPLICATION = 'mysite.wsgi.application'

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

AUTH_PASSWORD_VALIDATORS = [
    {
        'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
    },
]


LANGUAGE_CODE = 'en-us'

TIME_ZONE = 'UTC'

USE_I18N = True

USE_L10N = True

USE_TZ = True

STATIC_URL = '/static/'

STATICFILES_DIRS = (
    os.path.join(BASE_DIR,'static'),
)

STATIC_ROOT = os.path.join(BASE_DIR,'staticfiles')


MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR,'media')



EMAIL_BACKEND = 'django.core.mail.backends.console.EmailBackend'

网址.py:

from django.contrib import admin
from django.urls import path

from django.conf.urls import url,include
from blog import views
from django.conf import settings
from django.conf.urls.static import static

urlpatterns = [
    path('admin/', admin.site.urls),
    path('index/',views.index, name='index'),
    path('datetime/',views.current_datetime,name='datetime'),
    path('',views.post_list,name='post_list'),
    url(r'^blog/(?P<id>\d+)/(?P<slug>[\w-]+)/$',views.post_detail,name="post_detail"),
    url('post_create/',views.post_create,name = "post_create"),
    url('login/', views.user_login,name="user_login"),
    url('logout/', views.user_logout,name="user_logout"),
    url('register/',views.register,name="register"),

    url('',include('django.contrib.auth.urls')),
    url(r'^oauth/', include('social_django.urls', namespace="social")),

]

if settings.DEBUG:
    urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)


登录.html:

{% extends 'blog/base.html' %}
{% block content %}
   <form method = "post">
       {% csrf_token %}
       {{form.as_p}}


       <input type="submit" value="Login" class="btn btn-outline-success">

    <p> -- OR -- </p> 
    <a href="{% url 'social:begin' 'github' %}">
        <button type="button" name="button" class="btn btn-primary"> Github </button>
    </a>  
    <a href="{% url 'social:begin' 'google-oauth2' %}">
        <button type="button" name="button" class="btn btn-danger"> Google+ </button>
    </a>

    </form>   
{% endblock %}   

在浏览器中,当我点击 Google+ 按钮时,我会从“ http://127.0.0.1:8000/login/”中获取网址“http://127.0.0.1:8000/oauth/login/google-oauth2/ 但是我应该得到“401 error as invalid_client - The OAuth client was not found”,因为从这个页面的 url,我得到了在谷歌开发者控制台上设置 django 应用程序时需要的 uri 的值。谁能帮助我如何获取此错误页面?任何帮助,将不胜感激。

标签: djangopython-3.xsocial-authentication

解决方案


如果您使用电子邮件登录,请查看设置,您可能重复了 AUTHENTICATION_BACKENDS Review Settings Good 并确保您只使用一次并包括所有后端


推荐阅读