在 Django 中,是否可以在同一个应用程序中拥有 2 种不同类型的用户,并拥有自己的登录字段?

问题描述

我的网站上有两种类型的用户,一种是店主,我想用通常的自定义用户电子邮件和密码登录他,另一种是买家,我想只用 pin 登录买家号码而已。是否可以在同一个 django 应用程序中同时拥有两种类型的登录用户。提前致谢。

class Store(models.Model):
store_name = models.CharField(max_length=200)
store_status = models.BooleanField()
store_details = models.CharField(max_length=300,blank = True)
store_balance = models.IntegerField(default=0)
user = models.OnetoOneField(User,on_delete=models.CASCADE)
college = models.ForeignKey(Institute,on_delete=models.CASCADE )
def __str__(self):
    return str(self.store_name)+" "+ str(self.store_status)


class Customer(models.Model):
name = models.CharField(max_length=200)
branch = models.CharField(max_length=200,choices=BRANCHES)
sem = models.CharField(max_length=200,choices=SEMESTERS)
reg_no = models.IntegerField(default=0)
balance = models.IntegerField(default=0)
pin_no = models.IntegerField()
college = models.ForeignKey(Institute,on_delete=models.CASCADE )

解决方法

您有几种方法可以做到这一点。一个是制作一个索引位置,在那里他们选择“所有者”或“买家”选项,然后要求登录身份验证。其他方法是让 url 已经指定这些选项。如果您想在相同的“表单”中执行此操作,您可以在引擎盖下添加规范以管理此输入数据,也可以通过多种方式完成,或者创建一个复选框,例如更改表单输入。选择适合您的那一款。这对您有帮助吗?

,

要进行自定义身份验证,您需要添加一个身份验证后端。首先,您的客户模型与您的用户模型无关,请尝试在其中添加 OnetoOne 字段。之后尝试在您的应用程序之一中添加这样的代码:-

from django.contrib.auth.backends import BaseBackend

class MyBackend(BaseBackend):
    def authenticate(self,request,token=None):
        try:
            customer = Customer.objects.get(pin_no=token)
            user = customer.user
        except Customer.DoesNotExist:
            return None
        return user
    
    def get_user(self,user_id):
        try:
            return User.objects.get(pk=user_id)
        except User.DoesNotExist:
            return None

有关详细信息,请参阅 Customizing authentication in Django 上的文档。

现在,在创建 AuthenticationBackend 之后,您需要创建它以便 Django 使用它,您可以通过将其添加到 settings.py 中的 AUTHENTICATION_BACKENDS 来实现,因为您需要默认的用户名和密码保持这样的方式是可行的:

AUTHENTICATION_BACKENDS = ['django.contrib.auth.backends.ModelBackend','path.to.MyBackend']