溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何在Django中處理多用戶類型

發(fā)布時間:2021-05-20 17:12:29 來源:億速云 閱讀:234 作者:Leah 欄目:開發(fā)技術(shù)

如何在Django中處理多用戶類型?針對這個問題,這篇文章詳細介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

1. 不要使用 Django 內(nèi)置的 User 模型,盡管它能滿足應(yīng)用程序的所有要求。

正如官方Django文檔強烈建議為新項目使用自定義用戶模型。需求總是在變,只用固定的模型不太現(xiàn)實,并且一旦設(shè)置了 AUTH_USER_MODEL 后續(xù)再修改就很麻煩了。

2.無論最后選擇什么方案,無論有什么業(yè)務(wù),都始終只使用一個 Django 模型來處理身份驗證。

永遠都使用一個用戶模型,這就是標題為什么是處理多用戶類型而不是多用戶模型。這也就能使用統(tǒng)一的身份認證機制。它仍然可以擁有多種用戶類型。

方案

不同的項目要求設(shè)計出來的方案也是不同的,不妨先問問自己這幾個問題:

  • 需要維護多少種用戶類型?

  • 用戶可以同時擁有多種角色嗎?比如用戶可以同時成為學生或老師嗎?

  • 不同用戶類型是否需要存儲不同的信息?

一種非常常見的情況就是擁有普通用戶和管理員。在這種場景下,可以使用內(nèi)置的 is_staff 來區(qū)分普通用戶和管理員。實際上,內(nèi)置模型中有兩個字段來處理這種情況:is_staff 和 is_superuser 。is_staff 標志著用戶是否允許登錄 Django Admin 頁面,至于該用戶能做什么或不能做什么,就由權(quán)限框架來授權(quán)。而 is_superuser 是一個額外的標志,意味著擁有所有權(quán)限。所以這里可以看出來,權(quán)限有兩個級別的管理。

需要維護多少種用戶類型? 如果類型數(shù)量比較少,那就可以效仿Django的方式,用幾個字段來簡單表示:

class User(AbstractUser):
  is_student = models.BooleanField(default=False)
  is_teacher = models.BooleanField(default=False)

這可能是處理多種用戶類型最簡單的方法了。

另一種選擇是,只用一個字段就來表示用戶:

class User(AbstractUser):
 USER_TYPE_CHOICES = (
   (1, 'student'),
   (2, 'teacher'),
   (3, 'secretary'),
   (4, 'supervisor'),
   (5, 'admin'),
 )

 user_type = models.PositiveSmallIntegerField(choices=USER_TYPE_CHOICES)

超過 3 種類型可以選擇這種方式。

用戶可以同時擁有多種角色嗎?

如果用戶是可以同時承擔多種角色的話,那么就需要一個額外的表表示它們多對多的關(guān)系,顯然可以用到 ManyToManyField :

class Role(models.Model):
 '''
 The Role entries are managed by the system,
 automatically created via a Django data migration.
 '''
 STUDENT = 1
 TEACHER = 2
 SECRETARY = 3
 SUPERVISOR = 4
 ADMIN = 5
 ROLE_CHOICES = (
   (STUDENT, 'student'),
   (TEACHER, 'teacher'),
   (SECRETARY, 'secretary'),
   (SUPERVISOR, 'supervisor'),
   (ADMIN, 'admin'),
 )

 id = models.PositiveSmallIntegerField(choices=ROLE_CHOICES, primary_key=True)

 def __str__(self):
   return self.get_id_display()

class User(AbstractUser):
 roles = models.ManyToManyField(Role)

這種方案其實并不常見,因為Django已經(jīng)提供權(quán)限組的功能并擁有靈活的權(quán)限管理。你得評估下創(chuàng)建自定義權(quán)限組是否更好。

不同用戶類型是否需要存儲不同的信息? 如果存儲的信息(如頭像)與所有用戶相關(guān),那么最好的做法就是直接向用戶模型添加額外的字段。

如果儲存的信息只與特定的類型用戶有關(guān),那么可以用 OneToOneField 來進行拓展:

from django.contrib.auth.models import AbstractUser
from django.db import models

class User(AbstractUser):
  is_student = models.BooleanField(default=False)
  is_teacher = models.BooleanField(default=False)

class Student(models.Model):
  user = models.OneToOneField(User, on_delete=models.CASCADE, primary_key=True)
  ...

class Teacher(models.Model):
  user = models.OneToOneField(User, on_delete=models.CASCADE, primary_key=True)
  ...

總結(jié)

可以參照如下的流程圖來幫助設(shè)計:

如何在Django中處理多用戶類型

關(guān)于如何在Django中處理多用戶類型問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI