2017-08-14 12 views
2

Ich bin neu in Django. Immer, wenn ich mein Anmeldeformular form.is_valid() einreiche, gibt die Funktion in meiner Ansicht false zurück. Ich kann nicht herausfinden, wo ich falsch liege. Ich verwende die SignUpForm-Klasse für zusätzliche Felder. signup.html ist meine Vorlage. Anmeldung ist meine Ansichtsfunktion. Ist meine SignUpForm-Klasse in meinem forms.py falsch? Jede Hilfe wäre großartig. Ich habe auch alle Details in meinem Anmeldeformular ausgefüllt, aber immer noch form.is_valid() gibt in meinem Fall false zurück.Django is_valid() gibt false zurück

meiner Ansicht Funktion

def signup(request): 
    if request.method == 'POST': 
     form = SignUpForm(request.POST) 
     if form.is_valid(): 
      form.save() 
      return render(request, 'signup.html', {'message': 'Signed Up successfully'}) 
    return render(request, 'signup.html') 

mein forms.py

from django import forms 
from django.contrib.auth.forms import UserCreationForm 
from django.contrib.auth.models import User 


class SignUpForm(UserCreationForm): 
    first_name = forms.CharField(max_length=255) 
    last_name = forms.CharField(max_length=255) 
    password = forms.CharField(widget=forms.PasswordInput) 
    confirm_password = forms.CharField(widget=forms.PasswordInput) 
    phone_number = forms.CharField(max_length=100) 

    class Meta: 
     model = User 
     fields = ['username', 'email', 'first_name', 'last_name', 'password', 'confirm_password', 'phone_number'] 

mein base.html

<body style = "margin: 0;"> 
    <div class="row" style="padding-left: 2%;padding-top:1%;"> 
     <div class="col-md-9"> 
      <h2>Welcome to my site</h2> 
     </div> 
     <div class="col-md-2"> 
      <a href="{% url 'login' %}" class="btn btn-primary" style="margin-right: 6%;">Login</a><br><br><br> 
     </div> 
    </div> 


    <div class="row" style="margin-left: 4%"> 
     <form class="form-group" name="form1" id="form1" method="post" style="padding-top: 1%" action = "{% url 'signup' %}"> 
      {% csrf_token %} 
      <h3>Sign up</h3><br> 
      <div class="form-group row"> 
       <label id="user" class="col-4 col-form-label">Username</label> 
       <div class="col-8"> 
        <input class="form-control" type="text" name = "username" placeholder = "Username" required="true" > 
       </div> 
      </div> 
      <div class="form-group row"> 
       <label id="email" class="col-4 col-form-label">Email id</label> 
       <div class="col-8"> 
        <input class="form-control" type="text" name = "email" placeholder = "Email id" required="true" > 
       </div> 
      </div> 
      <div class="form-group row"> 
       <label id="first_name" class="col-4 col-form-label">First name</label> 
       <div class="col-8"> 
        <input class="form-control" type="text" name = "first_name" placeholder = "First name" required="true" > 
       </div> 
      </div> 
      <div class="form-group row"> 
       <label id="last_name" class="col-4 col-form-label">Last name</label> 
       <div class="col-8"> 
        <input class="form-control" type="text" name = "last_name" placeholder = "Last name" required="true" > 
       </div> 
      </div> 
      <div class="form-group row"> 
       <label id="password" class="col-4 col-form-label">Password</label> 
       <div class="col-8"> 
        <input class="form-control" type="password" name = "password" placeholder = "Password" required="true" > 
       </div> 
      </div> 
      <div class="form-group row"> 
       <label id="confirm_password" class="col-4 col-form-label">Re-enter Password</label> 
       <div class="col-8"> 
        <input class="form-control" type="password" name = "confirm_password" placeholder = "Password" required="true" > 
       </div> 
      </div> 
      <div class="form-group row"> 
       <label id="contact_number" class="col-4 col-form-label">Contact number</label> 
       <div class="col-8"> 
        <input class="form-control" type="text" name = "phone_number" placeholder = "Contact number" required="true" > 
       </div> 
      </div> 

      <input type = "submit" value = "Sign up" class="btn btn-primary"> 
     </form> 
     {% if message %} 
      {{ message }} 
     {% endif %} 
    </div> 
    <br> 
</body> 

meine signup.html die

base.html erstreckt
{% extends 'base.html' %} 

{% block content %} 
    <h2>Sign up</h2> 
    <form method="post" action="{% url 'signup' %}"> 
    {% csrf_token %} 
    {{ form.as_p }} 
    <button type="submit">Sign up</button> 
    </form> 
{% endblock %} 
+2

Sie können nach dem Ausführen von form.is_valid() nach Fehlern im form.errors-Attribut suchen. –

Antwort

3

Die UserCreationForm hat drei Felder: username, password1 und password2. Ihr Formular funktioniert nicht, weil Sie die Passwortfelder in password und confirm_password geändert haben.

Wenn Sie form.errors nach Überprüfung form.is_valid() überprüfen, werden Sie sehen, dass es Fehler für password1 und password2, weil sie von der Vorlage fehlen.

2

Sie versuchen, ein HTML-Formular zu rendern und es an Formulare zu übergeben. Sie müssen die Formulare mit der Django-Vorlage rendern. So etwas wie unten

{{ form.as_p }} 

Das wird die ganze Form in <p> Tags eingewickelt machen

Sie auch einzelne Felder mit Attributnamen machen können. Unter den Einsen wird ein HTML-Eingabefeld dargestellt, das auch mit <div> Tags versehen werden kann.

{{form.email}} 
{{form.first_name}} 

und so weiter.

Sie könnten auch

2

bei working with forms aussehen wollen Sie sollten die tatsächliche Form in Ihrer Vorlage verwenden, und nicht manuell schreiben. Beispiel:

views.py

def signup(request): 
    if request.method == 'POST': 
     form = SignUpForm(request.POST) 
     if form.is_valid(): 
      form.save() 
      return render(request, 'signup.html', {'message': 'Signed Up successfully'}) 

    else: 
     form = SignUpForm() 
    return render(request, 'signup.html', {form: form}) 

template.html

<form action="{% url 'signup' %}" method="post"> 
    {% csrf_token %} 
    {{ form }} 
    <input type="submit" value="Submit" /> 
</form> 

Ich würde vorschlagen, diesen ersten Versuch, heraus überprüfen, ob seine Arbeit, und dann über Styling Sorge, und die Formatierung. Hoffe das hilft!

+0

@Alasdair guten Fang, werde ich meine Antwort aktualisieren. Vielen Dank! –