如何将 django 中的管理页面与自定义身份验证后端连接起来?
How do I connect admin page in django with custom auth backend?
我在我的 Django 项目中使用自定义身份验证后端来连接用户,我的问题是我无法再使用管理界面进行连接。
这是我的自定义授权文件:
auth_backends.py:
from django.conf import settings
from django.contrib.auth.backends import ModelBackend
from django.core.exceptions import ImproperlyConfigured
from django.db.models import get_model
class StudentModelBackend(ModelBackend):
def authenticate(self, username=None, password=None):
try:
user = self.user_class_s.objects.get(username=username)
if user.check_password(password):
return user
except self.user_class_s.DoesNotExist:
return None
def get_user(self, user_id):
try:
return self.user_class_s.objects.get(pk=user_id)
except self.user_class_s.DoesNotExist:
return None
@property
def user_class_s(self):
if not hasattr(self, '_user_class'):
self._user_class = get_model(*settings.CUSTOM_USER_MODEL.split('.', 2))
if not self._user_class:
raise ImproperlyConfigured('Could not get student model')
return self._user_class
class ProfessorModelBackend(ModelBackend):
def authenticate(self, username=None, password=None):
try:
user = self.user_class_p.objects.get(username=username)
if user.check_password(password):
return user
except self.user_class_p.DoesNotExist:
return None
def get_user(self, user_id):
try:
return self.user_class_p.objects.get(pk=user_id)
except self.user_class_p.DoesNotExist:
return None
@property
def user_class_p(self):
if not hasattr(self, '_user_class'):
self._user_class = get_model(*settings.CUSTOM_USER_MODEL_P.split('.', 2))
if not self._user_class:
raise ImproperlyConfigured('Could not get student model')
return self._user_class
settings.py:
AUTHENTICATION_BACKENDS = (
'authentification.auth_backends.StudentModelBackend',
'authentification.auth_backends.ProfessorModelBackend',
)
CUSTOM_USER_MODEL = 'forum.Student'
CUSTOM_USER_MODEL_P = 'forum.Professor'
我试过这个解决方案:
从 django.contrib.auth.decorators 导入 login_required
admin.autodiscover()
admin.site.login = login_required(admin.site.login)
但它会将我重定向到用户身份验证界面而不是管理界面。
有人可以帮我吗?
默认的 login_required
装饰器将默认为 settings.py LOGIN_REDIRECT_URL
。但是,您也可以通过传递 login_url
关键字参数来明确告诉它使用哪个登录视图。
https://github.com/django/django/blob/stable/1.8.x/django/contrib/auth/decorators.py#L39
这可以与通用 login_required
视图一起使用,我下面的示例通过使用 user_passes_test
装饰器显示了更精确的条件。
例如:
from django.contrib.auth.decorators import user_passes_test
def superuser_required(*args, **kwargs):
return user_passes_test(lambda u: u.is_superuser, login_url='admin:login')(*args, **kwargs)
def custom_login_required(*args, **kwargs):
return user_passes_test(lambda u: getattr(u, 'is_custom_user', False), login_url='custom-url-name-from-urls-py')(*args, **kwargs)
然后你应该可以像上面那样使用这个新的装饰和通用 login_required
:
admin.site.login = custom_login_required(admin.site.login)
我找到了解决方案,
如果用户不是学生或教授,我只需要告诉 Django 尝试使用原始后端进行连接。
只需在 settings.py
中添加 'django.contrib.auth.backends.ModelBackend'
settings.py :
AUTHENTICATION_BACKENDS = (
'authentification.auth_backends.StudentModelBackend',
'authentification.auth_backends.ProfessorModelBackend',
'django.contrib.auth.backends.ModelBackend',
)
我在我的 Django 项目中使用自定义身份验证后端来连接用户,我的问题是我无法再使用管理界面进行连接。 这是我的自定义授权文件: auth_backends.py:
from django.conf import settings
from django.contrib.auth.backends import ModelBackend
from django.core.exceptions import ImproperlyConfigured
from django.db.models import get_model
class StudentModelBackend(ModelBackend):
def authenticate(self, username=None, password=None):
try:
user = self.user_class_s.objects.get(username=username)
if user.check_password(password):
return user
except self.user_class_s.DoesNotExist:
return None
def get_user(self, user_id):
try:
return self.user_class_s.objects.get(pk=user_id)
except self.user_class_s.DoesNotExist:
return None
@property
def user_class_s(self):
if not hasattr(self, '_user_class'):
self._user_class = get_model(*settings.CUSTOM_USER_MODEL.split('.', 2))
if not self._user_class:
raise ImproperlyConfigured('Could not get student model')
return self._user_class
class ProfessorModelBackend(ModelBackend):
def authenticate(self, username=None, password=None):
try:
user = self.user_class_p.objects.get(username=username)
if user.check_password(password):
return user
except self.user_class_p.DoesNotExist:
return None
def get_user(self, user_id):
try:
return self.user_class_p.objects.get(pk=user_id)
except self.user_class_p.DoesNotExist:
return None
@property
def user_class_p(self):
if not hasattr(self, '_user_class'):
self._user_class = get_model(*settings.CUSTOM_USER_MODEL_P.split('.', 2))
if not self._user_class:
raise ImproperlyConfigured('Could not get student model')
return self._user_class
settings.py:
AUTHENTICATION_BACKENDS = (
'authentification.auth_backends.StudentModelBackend',
'authentification.auth_backends.ProfessorModelBackend',
)
CUSTOM_USER_MODEL = 'forum.Student'
CUSTOM_USER_MODEL_P = 'forum.Professor'
我试过这个解决方案: 从 django.contrib.auth.decorators 导入 login_required
admin.autodiscover()
admin.site.login = login_required(admin.site.login)
但它会将我重定向到用户身份验证界面而不是管理界面。
有人可以帮我吗?
默认的 login_required
装饰器将默认为 settings.py LOGIN_REDIRECT_URL
。但是,您也可以通过传递 login_url
关键字参数来明确告诉它使用哪个登录视图。
https://github.com/django/django/blob/stable/1.8.x/django/contrib/auth/decorators.py#L39
这可以与通用 login_required
视图一起使用,我下面的示例通过使用 user_passes_test
装饰器显示了更精确的条件。
例如:
from django.contrib.auth.decorators import user_passes_test
def superuser_required(*args, **kwargs):
return user_passes_test(lambda u: u.is_superuser, login_url='admin:login')(*args, **kwargs)
def custom_login_required(*args, **kwargs):
return user_passes_test(lambda u: getattr(u, 'is_custom_user', False), login_url='custom-url-name-from-urls-py')(*args, **kwargs)
然后你应该可以像上面那样使用这个新的装饰和通用 login_required
:
admin.site.login = custom_login_required(admin.site.login)
我找到了解决方案, 如果用户不是学生或教授,我只需要告诉 Django 尝试使用原始后端进行连接。 只需在 settings.py
中添加 'django.contrib.auth.backends.ModelBackend'settings.py :
AUTHENTICATION_BACKENDS = (
'authentification.auth_backends.StudentModelBackend',
'authentification.auth_backends.ProfessorModelBackend',
'django.contrib.auth.backends.ModelBackend',
)