Django create_user with is_active=False
布爾值。指示用戶的賬號是否激活。我們建議把這個標(biāo)記設(shè)置為False 來代替刪除賬號;這樣的話,如果你的應(yīng)用和User 之間有外鍵關(guān)聯(lián),外鍵就不會失效。
它不是用來控制用戶是否能夠登錄。認證的后端沒有要求檢查is_active 標(biāo)記,而且默認的后端不會檢查。如果你想在is_active 為False 時拒絕用戶登錄,你需要在你自己的視圖或自定義的認證后端中作檢查。但是,默認的login() 視圖使用的AuthenticationForm 卻會 作這個檢查,正如在Django 的Admin 站點中所做的權(quán)限檢查方法如has_perm() 和認證一樣。對于未激活的用戶,所有這些函數(shù)/方法都返回False。
?
?
這里要說的就是將is_active設(shè)置為False,來阻止剛 注冊的用法登陸
password = password1user_profile = UserProfiles()user_profile.username = user_nameuser_profile.email = user_nameuser_profile.is_active = Falseuser_profile.password = make_password(password)user_profile.save()?這里是第一種比較笨辦法中的一段代碼: 簡單粗暴,直接實例化一個對象將其is_active設(shè)置為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,
關(guān)鍵就在這個extra_fields中,它可以指定其它所有的字段的值.
下面對上面笨辦法的一個補充:
UserProfiles.objects.create_user(username=user_name, password=password1, is_active=False)?這里的UserProfiles 和上面的UserProfiles都是自定義的繼承自User的Model,如果你沒有重寫User,這里需要先導(dǎo)入User
from django.contrib.auth.models import UserUser.objects.create_user(username=user_name, password=password1, is_active=False) # 并改成這樣
?同樣的道理,其它字段也可以自己指定.
轉(zhuǎn)載于:https://www.cnblogs.com/Andy963/p/8551458.html
總結(jié)
以上是生活随笔為你收集整理的Django create_user with is_active=False的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 平民版均线量化交易模型
- 下一篇: 栈顶缓存技术