You should remove the inner else: clause and the redirect() line. If
is_valid() fails, the last return statement will be used, which will pass
along the bound form in signup_form that was snagged inside of your first
if statement. Mimic the behavior here:
https://docs.djangoproject.com/en/1.7/topics/forms/#the-view

BTW, django.shortcuts.redirect should handle the reverse() for you, so you
can take that out to make your code a bit cleaner. Also, not sure if this
is a copy/paste issue, but I think render() requires that request be sent
along as the first argument, although I don't use FBV's, so don't quote me
on that.

-James

On Wed, Jan 7, 2015 at 6:03 AM, 赵飞 <xuezai...@gmail.com> wrote:

> I want to make a signup page just like:
>
>
> <https://lh5.googleusercontent.com/-BYeglZkQ0cM/VK06PkzpdPI/AAAAAAAAAN0/l5xB5VdkbJk/s1600/%E5%B1%8F%E5%B9%95%E5%BF%AB%E7%85%A7%2B2015-01-07%2B%E4%B8%8B%E5%8D%889.52.08.png>
> When user click signup, I want to check the if the two password are the
> same, when not, give a error message after "confirm password".  Here is my
> code:
>
> *forms.py*
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
> *class SignupForm(forms.Form):    username = forms.CahrField(
> label=_("username"),        max_length=30,    )    email =
> forms.EmailField(label=_('email'),)    password_1 = forms.CharField(
> label=_("password"),        widget=forms.PasswordInput,    )    password_2
> = forms.CharField(        label=_("password_confirmed"),
> widget=forms.PasswordInput,    )    def clean_password_2(self):
> password_1 = self.cleaned_data.get("password_1")        password_2 =
> self.cleaned_data.get("password_2")        if password_1 and password_2 and
> password_1 != password_2:            raise
> forms.ValidationError(_('password confirm failed'))        return
> password_2 signup.html*
>
> <form method="post" action="{% url 'accounts:signup_post' %}">
>     {% csrf_token %}
>     <table>
>     {% for field in form %}
>         <tr>
>             <td>{{ field.label_tag }}</td>
>             <td>{{ field }}</td>
>             <td>{{ field.errors }}</td>
>         </tr>
>     {% endfor %}
>     </table>
>
>     <input type='submit' id="submit" value={% trans "signup" %}>
>     <a href="{% url 'accounts:login' %}">{% trans "Already have
> accounts?" %}</a>
> </form>
>
>
>
> *views.py*
>
> def signup_post(request):
>     if request.method == 'POST':
>         signup_form = forms.SignupForm(request.POST)
>
>         if signup_form.is_valid():
>             signup_info = signup_form.cleaned_data
>             username = signup_info['username']
>             email = signup_info['email']
>             password = signup_info['password_1']
>             user = User.objects.create_user(
>                 username=username,
>                 email=email,
>                 password=password)
>             user.save()
>             # redirect to main page(not written so far)
>         else:
>             # I guess something wrong here, but no idea how to fix it.
>             return redirect(reverse("accounts:signup"))
>
>     else:
>         signup_form = forms.SignupForm()
>
>     return render(reverse("accounts:signup"), {'form': signup_form})
>
> Can anyone help me out?
> *Thanks!*
>
> --
> You received this message because you are subscribed to the Google Groups
> "Django users" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to django-users+unsubscr...@googlegroups.com.
> To post to this group, send email to django-users@googlegroups.com.
> Visit this group at http://groups.google.com/group/django-users.
> To view this discussion on the web visit
> https://groups.google.com/d/msgid/django-users/d969fed6-5041-4093-aa35-35d611993cd3%40googlegroups.com
> <https://groups.google.com/d/msgid/django-users/d969fed6-5041-4093-aa35-35d611993cd3%40googlegroups.com?utm_medium=email&utm_source=footer>
> .
> For more options, visit https://groups.google.com/d/optout.
>

-- 
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to django-users+unsubscr...@googlegroups.com.
To post to this group, send email to django-users@googlegroups.com.
Visit this group at http://groups.google.com/group/django-users.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/django-users/CA%2Be%2BciUcZytC8tQk8CtH_p5PSrpCCZTszhP-W1ywhdQ61aMPKw%40mail.gmail.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to