Kolba - WTF
Jednym z podstawowych aspektów aplikacji internetowej jest przedstawienie użytkownikowi interfejsu użytkownika. HTML zapewnia<form>tag, który służy do projektowania interfejsu. ZAForm’s elementy takie jak wprowadzanie tekstu, radio, wybór itp. mogą być odpowiednio używane.
Dane wprowadzone przez użytkownika są przesyłane w postaci komunikatu żądania HTTP do skryptu po stronie serwera metodą GET lub POST.
Skrypt po stronie serwera musi odtworzyć elementy formularza z danych żądania http. W efekcie elementy formularzy muszą być zdefiniowane dwukrotnie - raz w HTML i ponownie w skrypcie po stronie serwera.
Inną wadą korzystania z formularza HTML jest to, że jest trudne (jeśli nie niemożliwe) dynamiczne renderowanie elementów formularza. Sam HTML nie zapewnia możliwości sprawdzenia poprawności danych wejściowych użytkownika.
To jest gdzie WTForms, przydaje się elastyczna biblioteka formularzy, renderowania i walidacji. Rozszerzenie Flask-WTF zapewnia prosty interfejs z tymWTForms biblioteka.
Za pomocą Flask-WTF, możemy zdefiniować pola formularza w naszym skrypcie Python i renderować je za pomocą szablonu HTML. Możliwe jest również zastosowanie walidacji doWTF pole.
Zobaczmy, jak działa ta dynamiczna generacja HTML.
Najpierw należy zainstalować rozszerzenie Flask-WTF.
pip install flask-WTF
Zainstalowany pakiet zawiera plik Form klasa, która musi być używana jako rodzic dla formularza zdefiniowanego przez użytkownika.
WTformspakiet zawiera definicje różnych pól formularza. TrochęStandard form fields są wymienione poniżej.
Sr.No | Standardowe pola formularza i opis |
---|---|
1 | TextField Reprezentuje element formularza HTML <input type = 'text'> |
2 | BooleanField Reprezentuje element formularza HTML <input type = 'checkbox'> |
3 | DecimalField Pole tekstowe do wyświetlania liczby z miejscami dziesiętnymi |
4 | IntegerField TextField do wyświetlania liczby całkowitej |
5 | RadioField Reprezentuje element formularza HTML <input type = 'radio'> |
6 | SelectField Reprezentuje wybrany element formularza |
7 | TextAreaField Reprezentuje element formularza html <testarea> |
8 | PasswordField Reprezentuje element formularza HTML <input type = 'password'> |
9 | SubmitField Reprezentuje element formularza <input type = 'submit'> |
Na przykład formularz zawierający pole tekstowe można zaprojektować jak poniżej -
from flask_wtf import Form
from wtforms import TextField
class ContactForm(Form):
name = TextField("Name Of Student")
Dodatkowo ‘name’pole ukryte pole dla tokena CSRF jest tworzone automatycznie. Ma to zapobiecCross Site Request Forgery atak.
Po wyrenderowaniu spowoduje to powstanie równoważnego skryptu HTML, jak pokazano poniżej.
<input id = "csrf_token" name = "csrf_token" type = "hidden" />
<label for = "name">Name Of Student</label><br>
<input id = "name" name = "name" type = "text" value = "" />
Klasa formularza zdefiniowana przez użytkownika jest używana w aplikacji Flask, a formularz jest renderowany przy użyciu szablonu.
from flask import Flask, render_template
from forms import ContactForm
app = Flask(__name__)
app.secret_key = 'development key'
@app.route('/contact')
def contact():
form = ContactForm()
return render_template('contact.html', form = form)
if __name__ == '__main__':
app.run(debug = True)
Pakiet WTForms zawiera również klasę walidatora. Jest to przydatne przy stosowaniu walidacji do pól formularza. Poniższa lista przedstawia często używane walidatory.
Sr.No | Klasa i opis walidatorów |
---|---|
1 | DataRequired Sprawdza, czy pole wejściowe jest puste |
2 | Sprawdza, czy tekst w polu jest zgodny z konwencjami identyfikatora e-mail |
3 | IPAddress Sprawdza adres IP w polu wejściowym |
4 | Length Sprawdza, czy długość łańcucha w polu wejściowym mieści się w podanym zakresie |
5 | NumberRange Weryfikuje liczbę w polu wejściowym w podanym zakresie |
6 | URL Sprawdza adres URL wprowadzony w polu wejściowym |
Teraz będziemy się składać ‘DataRequired’ reguła walidacji dla name pole w formularzu kontaktowym.
name = TextField("Name Of Student",[validators.Required("Please enter your name.")])
Plik validate()funkcja obiektu form sprawdza poprawność danych formularza i zgłasza błędy walidacji, jeśli walidacja się nie powiedzie. PlikErrorwiadomości są wysyłane do szablonu. W szablonie HTML komunikaty o błędach są renderowane dynamicznie.
{% for message in form.name.errors %}
{{ message }}
{% endfor %}
Poniższy przykład ilustruje pojęcia podane powyżej. ProjektContact form podano poniżej (forms.py).
from flask_wtf import Form
from wtforms import TextField, IntegerField, TextAreaField, SubmitField, RadioField,
SelectField
from wtforms import validators, ValidationError
class ContactForm(Form):
name = TextField("Name Of Student",[validators.Required("Please enter
your name.")])
Gender = RadioField('Gender', choices = [('M','Male'),('F','Female')])
Address = TextAreaField("Address")
email = TextField("Email",[validators.Required("Please enter your email address."),
validators.Email("Please enter your email address.")])
Age = IntegerField("age")
language = SelectField('Languages', choices = [('cpp', 'C++'),
('py', 'Python')])
submit = SubmitField("Send")
Walidatory są stosowane do Name i Email pola.
Poniżej podano skrypt aplikacji Flask (formexample.py).
from flask import Flask, render_template, request, flash
from forms import ContactForm
app = Flask(__name__)
app.secret_key = 'development key'
@app.route('/contact', methods = ['GET', 'POST'])
def contact():
form = ContactForm()
if request.method == 'POST':
if form.validate() == False:
flash('All fields are required.')
return render_template('contact.html', form = form)
else:
return render_template('success.html')
elif request.method == 'GET':
return render_template('contact.html', form = form)
if __name__ == '__main__':
app.run(debug = True)
Skrypt szablonu (contact.html) wygląda następująco -
<!doctype html>
<html>
<body>
<h2 style = "text-align: center;">Contact Form</h2>
{% for message in form.name.errors %}
<div>{{ message }}</div>
{% endfor %}
{% for message in form.email.errors %}
<div>{{ message }}</div>
{% endfor %}
<form action = "http://localhost:5000/contact" method = post>
<fieldset>
<legend>Contact Form</legend>
{{ form.hidden_tag() }}
<div style = font-size:20px; font-weight:bold; margin-left:150px;>
{{ form.name.label }}<br>
{{ form.name }}
<br>
{{ form.Gender.label }} {{ form.Gender }}
{{ form.Address.label }}<br>
{{ form.Address }}
<br>
{{ form.email.label }}<br>
{{ form.email }}
<br>
{{ form.Age.label }}<br>
{{ form.Age }}
<br>
{{ form.language.label }}<br>
{{ form.language }}
<br>
{{ form.submit }}
</div>
</fieldset>
</form>
</body>
</html>
Biegać formexample.py w powłoce Pythona i odwiedź adres URL http://localhost:5000/contact. PlikContact zostanie wyświetlony formularz, jak pokazano poniżej.
Jeśli są jakieś błędy, strona będzie wyglądać następująco -
Jeśli nie ma błędów, ‘success.html’ zostaną wyrenderowane.