Flacon - WTF
L'un des aspects essentiels d'une application Web est de présenter une interface utilisateur pour l'utilisateur. HTML fournit un<form>tag, qui est utilisé pour concevoir une interface. UNEForm’s des éléments tels que la saisie de texte, la radio, la sélection, etc. peuvent être utilisés de manière appropriée.
Les données saisies par un utilisateur sont soumises sous la forme d'un message de requête Http au script côté serveur par la méthode GET ou POST.
Le script côté serveur doit recréer les éléments de formulaire à partir des données de requête http. Donc, en fait, les éléments de formulaire doivent être définis deux fois - une fois en HTML et à nouveau dans le script côté serveur.
Un autre inconvénient de l'utilisation d'un formulaire HTML est qu'il est difficile (voire impossible) de rendre les éléments du formulaire de manière dynamique. Le HTML lui-même ne fournit aucun moyen de valider l'entrée d'un utilisateur.
C'est ici que WTForms, une bibliothèque flexible de formulaires, de rendu et de validation est pratique. L'extension Flask-WTF fournit une interface simple avec ceWTForms bibliothèque.
En utilisant Flask-WTF, nous pouvons définir les champs de formulaire dans notre script Python et les rendre à l'aide d'un modèle HTML. Il est également possible d'appliquer la validation auWTF champ.
Voyons comment fonctionne cette génération dynamique de HTML.
Tout d'abord, l'extension Flask-WTF doit être installée.
pip install flask-WTF
Le package installé contient un Form class, qui doit être utilisé comme parent pour le formulaire défini par l'utilisateur.
WTformspackage contient les définitions de divers champs de formulaire. CertainsStandard form fields sont énumérés ci-dessous.
Sr.Non | Champs de formulaire standard et description |
---|---|
1 | TextField Représente l'élément de formulaire HTML <input type = 'text'> |
2 | BooleanField Représente l'élément de formulaire HTML <input type = 'checkbox'> |
3 | DecimalField Champ de texte pour afficher le nombre avec des décimales |
4 | IntegerField TextField pour afficher un entier |
5 | RadioField Représente l'élément de formulaire HTML <input type = 'radio'> |
6 | SelectField Représente l'élément de formulaire de sélection |
sept | TextAreaField Représente l'élément de formulaire HTML <testarea> |
8 | PasswordField Représente l'élément de formulaire HTML <input type = 'password'> |
9 | SubmitField Représente l'élément de formulaire <input type = 'submit'> |
Par exemple, un formulaire contenant un champ de texte peut être conçu comme ci-dessous -
from flask_wtf import Form
from wtforms import TextField
class ContactForm(Form):
name = TextField("Name Of Student")
En plus de ‘name’, un champ masqué pour le jeton CSRF est créé automatiquement. C'est pour empêcherCross Site Request Forgery attaque.
Une fois rendu, cela se traduira par un script HTML équivalent, comme indiqué ci-dessous.
<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 = "" />
Une classe de formulaire définie par l'utilisateur est utilisée dans une application Flask et le formulaire est rendu à l'aide d'un modèle.
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)
Le package WTForms contient également une classe de validation. Il est utile pour appliquer la validation aux champs de formulaire. La liste suivante montre les validateurs couramment utilisés.
Sr.Non | Classe et description des validateurs |
---|---|
1 | DataRequired Vérifie si le champ de saisie est vide |
2 | Vérifie si le texte du champ respecte les conventions d'ID d'e-mail |
3 | IPAddress Valide l'adresse IP dans le champ de saisie |
4 | Length Vérifie si la longueur de la chaîne dans le champ d'entrée est dans la plage donnée |
5 | NumberRange Valide un nombre dans le champ de saisie dans une plage donnée |
6 | URL Valide l'URL saisie dans le champ de saisie |
Nous allons maintenant appliquer ‘DataRequired’ règle de validation pour le name champ dans le formulaire de contact.
name = TextField("Name Of Student",[validators.Required("Please enter your name.")])
le validate()La fonction de l'objet de formulaire valide les données du formulaire et renvoie les erreurs de validation si la validation échoue. leErrorles messages sont envoyés au modèle. Dans le modèle HTML, les messages d'erreur sont rendus dynamiquement.
{% for message in form.name.errors %}
{{ message }}
{% endfor %}
L'exemple suivant illustre les concepts donnés ci-dessus. La conception deContact form est donné ci-dessous (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")
Les validateurs sont appliqués au Name et Email des champs.
Ci-dessous, le script d'application 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)
Le script du modèle (contact.html) est comme suit -
<!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>
Courir formexample.py dans le shell Python et visitez l'URL http://localhost:5000/contact. leContact Le formulaire sera affiché comme indiqué ci-dessous.
S'il y a des erreurs, la page ressemblera à ceci -
S'il n'y a pas d'erreur, ‘success.html’ sera rendu.