django用户中的多个登录字段

时间:2015-06-16 22:12:21

标签: python django

使用Django用户时可能会以某种方式使用多个登录字段? 就像在Facebook中我们可以使用用户名,电子邮件和电话号码登录。

1 个答案:

答案 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/