Django UserCreationForm修改:密码未设置
使用此设置,当有人在注册页面上提交表单时,不会存储密码。但是,用户名和电子邮件是存储的。所有内容都精确显示,其中“password1”和“password2”链接到网页中的“密码”和“密码确认”输入字段。使用默认的UserCreationForm就可以了。有人知道我丢失了什么代码吗 forms.py:Django UserCreationForm修改:密码未设置,django,django-forms,django-views,django-users,Django,Django Forms,Django Views,Django Users,使用此设置,当有人在注册页面上提交表单时,不会存储密码。但是,用户名和电子邮件是存储的。所有内容都精确显示,其中“password1”和“password2”链接到网页中的“密码”和“密码确认”输入字段。使用默认的UserCreationForm就可以了。有人知道我丢失了什么代码吗 forms.py: from django import forms from django.contrib.auth.models import User from django.contrib.auth.form
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 user
views.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 %}
{%extends“directory/base.html”%}
{%block content%}
登记
{%csrf_令牌%}
{{form}}
{%endblock%}
试试这个:
user.email = self.cleaned_data['email']
user.set_password(self.cleaned_data['password1'])
user.save()
试试这个:
user.email = self.cleaned_data['email']
user.set_password(self.cleaned_data['password1'])
user.save()
试试这个:
user.email = self.cleaned_data['email']
user.set_password(self.cleaned_data['password1'])
user.save()
试试这个:
user.email = self.cleaned_data['email']
user.set_password(self.cleaned_data['password1'])
user.save()
我正在处理Mike Hibbert的Django教程中完全相同的代码。这里也回答了这个问题: 保存表单时,在MyRegistrationForm而不是UserCreationForm上调用super:
def save(self, commit=True):
user = super(MyRegistrationForm, self).save(commit=False)
...
我正在处理Mike Hibbert的Django教程中完全相同的代码。这里也回答了这个问题: 保存表单时,在MyRegistrationForm而不是UserCreationForm上调用super:
def save(self, commit=True):
user = super(MyRegistrationForm, self).save(commit=False)
...
我正在处理Mike Hibbert的Django教程中完全相同的代码。这里也回答了这个问题: 保存表单时,在MyRegistrationForm而不是UserCreationForm上调用super:
def save(self, commit=True):
user = super(MyRegistrationForm, self).save(commit=False)
...
我正在处理Mike Hibbert的Django教程中完全相同的代码。这里也回答了这个问题: 保存表单时,在MyRegistrationForm而不是UserCreationForm上调用super:
def save(self, commit=True):
user = super(MyRegistrationForm, self).save(commit=False)
...