Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/299.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 保持User.email在Django Admin中的唯一性_Python_Django_Django Authentication - Fatal编程技术网

Python 保持User.email在Django Admin中的唯一性

Python 保持User.email在Django Admin中的唯一性,python,django,django-authentication,Python,Django,Django Authentication,我使用的是Django 1.3/Python 2.7 我的应用程序正在使用django.contrib.auth进行用户管理。对于主用户注册,我有一个表格,用于检查“电子邮件”是否已注册。因此,它确保所有电子邮件字段都是唯一的 但是,有些管理员使用django管理界面添加用户,最终使用相同的电子邮件添加重复的帐户 为此,我创建了一个新的UserCreationForm,其中复制了django.contrib.auth.UserCreationForm,并向其中添加了一个“email”字段 cla

我使用的是Django 1.3/Python 2.7

我的应用程序正在使用django.contrib.auth进行用户管理。对于主用户注册,我有一个表格,用于检查“电子邮件”是否已注册。因此,它确保所有电子邮件字段都是唯一的

但是,有些管理员使用django管理界面添加用户,最终使用相同的电子邮件添加重复的帐户

为此,我创建了一个新的UserCreationForm,其中复制了django.contrib.auth.UserCreationForm,并向其中添加了一个“email”字段

class NewUserCreationForm(forms.ModelForm):
    """                                                                                                                                                                                                             
    A form that creates a user, with no privileges, from the given username and password.                                                                                                                           
    """
    username = forms.RegexField(label=_("Username"), max_length=30, regex=r'^[\w.@+-]+$',
        help_text = _("Required. 30 characters or fewer. Letters, digits and @/./+/-/_ only."),
        error_messages = {'invalid': _("This value may contain only letters, numbers and @/./+/-/_ characters.")})
    password1 = forms.CharField(label=_("Password"), widget=forms.PasswordInput)
    password2 = forms.CharField(label=_("Password confirmation"), widget=forms.PasswordInput,
        help_text = _("Enter the same password as above, for verification."))
    email = forms.EmailField(label=_("Email"), max_length=75)

    class Meta:
        model = User
        fields = ("username", "email")

    def clean_username(self):
        username = self.cleaned_data["username"]
        try:
            User.objects.get(username=username)
        except User.DoesNotExist:
            return username
        raise forms.ValidationError(_("A user with that username already exists."))

    def clean_password2(self):
        password1 = self.cleaned_data.get("password1", "")
        password2 = self.cleaned_data["password2"]
        if password1 != password2:
            raise forms.ValidationError(_("The two password fields didn't match."))
        return password2

    def save(self, commit=True):
        user = super(NewUserCreationForm, self).save(commit=False)
        user.set_password(self.cleaned_data["password1"])
        user.email = self.email
        if commit:
            user.save()
        return user


class CustomUserAdmin(UserAdmin):
    add_form = NewUserCreationForm


admin.site.unregister(User)
admin.site.register(User, CustomUserAdmin)
但是这个代码不起作用。我可以看到表单呈现,但没有电子邮件字段,只有用户名、密码1和密码2字段


我在这里错过了什么?

你错过了。。。UserAdmin.add_字段集,例如:

class CustomUserAdmin(UserAdmin):
    add_form = NewUserCreationForm
    add_fieldsets = (
        (None, {
            'classes': ('wide',),
            'fields': ('username', 'password1', 'password2', 'email')}
        ), 
    )  

发布代码的荣誉。注意:您可能应该扩展UserAdmin而不是fork。@jpic是的,我想先扩展它。那是干的。但是,Django的文档非常糟糕(很棒的教程,但和文档一样糟糕),他们只为UserCreationForm放了一行。文档可能不太好,但您可以随时查看代码本身。@ThomasOrozco是的,的确如此。我是Django的新手(大约6个月了),最近我开始在需要的时候阅读代码,对于如此庞大的项目,代码库的可读性令人惊讶。但好的文档是绝对必要的,尤其是对于那些新加入生态系统的人。我刚刚在一位同事的帮助下找到了答案,并补充了答案。无论如何,谢谢你的回答。