使用此设置,当有人在注册页上提交表单时,密码不会被存储。但是,用户名和电子邮件是存储的。所有内容都会准确显示,网页中的“password1”和“password2”链接到“密码”和“密码确认”输入字段。相反,使用默认的UserCreationForm可以正常工作。有人知道我遗漏了什么密码吗?
forms.py:
from django import forms
from django.contrib.auth.models import User
from django.contrib.auth.forms import UserCreationForm
class MyRegistrationForm(UserCreationForm):
email = forms.EmailField(required=True)
class Meta:
model = User
fields = ['username', 'email', 'password1', 'password2']
def save(self, commit=True):
user = super(UserCreationForm, self).save(commit=False)
user.email = self.cleaned_data['email']
if commit:
user.save()
return userviews.py:
from django.shortcuts import render_to_response
from django.http import HttpResponseRedirect
from django.contrib import auth
from django.core.context_processors import csrf
from mainsite.forms import MyRegistrationForm
...
def register_user(request):
if request.method == 'POST':
form = MyRegistrationForm(request.POST)
if form.is_valid():
form.save()
return HttpResponseRedirect('/accounts/register_success')
args = {}
args.update(csrf(request))
args['form'] = MyRegistrationForm()
return render_to_response('directory/register.html', args)
def register_success(request):
return render_to_response('directory/register_success.html')register.html:
{% extends "directory/base.html" %}
{% block content %}
<h2>Register</h2>
<form action="/accounts/register/" method="post">{% csrf_token %}
{{ form }}
<input type="submit" value="register" />
</form>
{% endblock %}发布于 2015-07-21 09:41:03
试试这个:
user.email = self.cleaned_data['email']
user.set_password(self.cleaned_data['password1'])
user.save()发布于 2017-10-11 10:37:19
我正在处理来自Mike的Django教程的完全相同的代码。这个问题在这里也得到了回答:django - no password set after successful registration
保存表单时,请在MyRegistrationForm上调用super而不是UserCreationForm:
def save(self, commit=True):
user = super(MyRegistrationForm, self).save(commit=False)
...https://stackoverflow.com/questions/31535398
复制相似问题