使用Django用户时可能会以某种方式使用多个登录字段? 就像在Facebook中我们可以使用用户名,电子邮件和电话号码登录。
答案 0 :(得分:6)
是的,它是!您可以编写自己的身份验证后端,如本节所述: https://docs.djangoproject.com/en/1.8/topics/auth/customizing/
我们假设您已创建了一个应用程序帐户/,您可以在其中扩展其他电话字段的用户模型。 在帐户内创建auth后端backends.py,并编写自己的身份验证逻辑。例如:
from account.models import UserProfile
from django.db.models import Q
class AuthBackend(object):
supports_object_permissions = True
supports_anonymous_user = False
supports_inactive_user = False
def get_user(self, user_id):
try:
return UserProfile.objects.get(pk=user_id)
except UserProfile.DoesNotExist:
return None
def authenticate(self, username, password):
try:
user = UserProfile.objects.get(
Q(username=username) | Q(email=username) | Q(phone=username)
)
except UserProfile.DoesNotExist:
return None
return user if user.check_password(password) else None
将自定义后端放在项目的settings.py:
中AUTHENTICATION_BACKENDS = ('account.backends.AuthBackend',)
然后通过在POST的用户名字段中传递用户名,电子邮件或电话进行身份验证。
from django.contrib.auth import authenticate, login
def my_view(request):
username = request.POST['username']
password = request.POST['password']
user = authenticate(username=username, password=password)
if user is not None:
if user.is_active:
login(request, user)
# Redirect to a success page.
else:
# Return a 'disabled account' error message
...
else:
# Return an 'invalid login' error message.
...
请参阅:https://docs.djangoproject.com/fr/1.8/topics/auth/default/