Django create_user with is_active=False


下面的內容來自官方文檔
is_active

布爾值。指示用戶的賬號是否激活。我們建議把這個標記設置為False 來代替刪除賬號;這樣的話,如果你的應用和User 之間有外鍵關聯,外鍵就不會失效。

它不是用來控制用戶是否能夠登錄。認證的后端沒有要求檢查is_active 標記,而且默認的后端不會檢查。如果你想在is_activeFalse 時拒絕用戶登錄,你需要在你自己的視圖或自定義的認證后端中作檢查。但是,默認的login() 視圖使用的AuthenticationForm 卻會 作這個檢查,正如在Django 的Admin 站點中所做的權限檢查方法如has_perm() 和認證一樣。對於未激活的用戶,所有這些函數/方法都返回False

 

 

這里要說的就是將is_active設置為False,來阻止剛 注冊的用法登陸

            password = password1
            user_profile = UserProfiles()
            user_profile.username = user_name
            user_profile.email = user_name
            user_profile.is_active = False
            user_profile.password = make_password(password)
            user_profile.save()

 這里是第一種比較笨辦法中的一段代碼: 簡單粗暴,直接實例化一個對象將其is_active設置為False

 

但是Django自帶的auth模塊中有更簡單的辦法, create_user

看下面源碼:

    def create_user(self, email, password=None, **extra_fields):

        is_staff = extra_fields.pop('is_staff', False)
        return self._create_user(email=email, password=password, 
                                 is_staff=is_staff, is_superuser=False,
                                 **extra_fields)

 很顯然, 常見的字段只有email, password, is_staff, is_supersuer etc. 但是還有一個**extra_fields,

關鍵就在這個extra_fields中,它可以指定其它所有的字段的值.

下面對上面笨辦法的一個補充:

            UserProfiles.objects.create_user(username=user_name, password=password1, is_active=False)

 這里的UserProfiles 和上面的UserProfiles都是自定義的繼承自User的Model,如果你沒有重寫User,這里需要先導入User

from django.contrib.auth.models import User
User.objects.create_user(username=user_name, password=password1, is_active=False) # 並改成這樣

 同樣的道理,其它字段也可以自己指定.


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM