फ्लास्क - डब्ल्यूटीएफ
वेब एप्लिकेशन के आवश्यक पहलुओं में से एक उपयोगकर्ता के लिए उपयोगकर्ता इंटरफ़ेस प्रस्तुत करना है। HTML एक प्रदान करता है<form>टैग, जिसका उपयोग एक इंटरफ़ेस डिज़ाइन करने के लिए किया जाता है। एForm’s पाठ इनपुट, रेडियो, चयन आदि जैसे तत्वों का उचित उपयोग किया जा सकता है।
उपयोगकर्ता द्वारा दर्ज किया गया डेटा GET या POST विधि द्वारा सर्वर साइड स्क्रिप्ट को Http अनुरोध संदेश के रूप में प्रस्तुत किया जाता है।
सर्वर साइड स्क्रिप्ट को http अनुरोध डेटा से फार्म तत्वों को फिर से बनाना है। तो वास्तव में, फार्म तत्वों को दो बार परिभाषित किया जाना है - एक बार HTML में और फिर से सर्वर साइड स्क्रिप्ट में।
HTML फॉर्म का उपयोग करने का एक और नुकसान यह है कि फॉर्म के तत्वों को गतिशील रूप से प्रस्तुत करना कठिन (यदि असंभव नहीं है)। HTML ही उपयोगकर्ता के इनपुट को मान्य करने का कोई तरीका प्रदान नहीं करता है।
यह कहाँ है WTForms, एक लचीला रूप, प्रतिपादन और सत्यापन पुस्तकालय काम आता है। फ्लास्क-डब्ल्यूटीएफ विस्तार इसके साथ एक सरल इंटरफ़ेस प्रदान करता हैWTForms पुस्तकालय।
का उपयोग करते हुए Flask-WTF, हम अपनी पायथन लिपि में प्रपत्र फ़ील्ड्स को परिभाषित कर सकते हैं और HTML टेम्पलेट का उपयोग करके उन्हें प्रस्तुत कर सकते हैं। के लिए सत्यापन लागू करना भी संभव हैWTF मैदान।
आइए देखते हैं कि HTML की यह गतिशील पीढ़ी कैसे काम करती है।
सबसे पहले, फ्लास्क-डब्ल्यूटीएफ एक्सटेंशन को स्थापित करने की आवश्यकता है।
pip install flask-WTF
स्थापित पैकेज में ए शामिल है Form वर्ग, जिसका उपयोग उपयोगकर्ता के लिए माता-पिता के रूप में परिभाषित रूप में किया जाना है।
WTformsपैकेज में विभिन्न फॉर्म फ़ील्ड की परिभाषाएँ हैं। कुछStandard form fields नीचे सूचीबद्ध हैं।
अनु क्रमांक | मानक प्रपत्र फ़ील्ड और विवरण |
---|---|
1 | TextField प्रतिनिधित्व करता है <इनपुट प्रकार = 'पाठ'> एचटीएमएल फार्म तत्व |
2 | BooleanField प्रतिनिधित्व करता है <इनपुट प्रकार = 'चेकबॉक्स'> एचटीएमएल फार्म तत्व |
3 | DecimalField दशमलव के साथ संख्या प्रदर्शित करने के लिए टेक्स्टफील्ड |
4 | IntegerField पूर्णांक प्रदर्शित करने के लिए TextField |
5 | RadioField प्रतिनिधित्व करता है <इनपुट प्रकार = 'रेडियो'> एचटीएमएल फॉर्म तत्व |
6 | SelectField रिप्रेंटेंट्स फॉर्म एलिमेंट का चयन करते हैं |
7 | TextAreaField प्रतिनिधित्व करता है <testarea> html रूप तत्व |
8 | PasswordField प्रतिनिधित्व करता है <इनपुट प्रकार = 'पासवर्ड'> एचटीएमएल फॉर्म तत्व |
9 | SubmitField प्रतिनिधित्व <इनपुट प्रकार = 'सबमिट'> फार्म तत्व |
उदाहरण के लिए, एक टेक्स्ट फ़ील्ड वाले फ़ॉर्म को नीचे के रूप में डिज़ाइन किया जा सकता है -
from flask_wtf import Form
from wtforms import TextField
class ContactForm(Form):
name = TextField("Name Of Student")
इसके अलावा ‘name’फ़ील्ड, CSRF टोकन के लिए एक छिपा हुआ फ़ील्ड स्वचालित रूप से बनाया जाता है। इससे बचाव करना हैCross Site Request Forgery हमला।
जब रेंडर किया जाता है, तो यह नीचे दिखाए गए अनुसार एक समकक्ष HTML स्क्रिप्ट में होगा।
<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 = "" />
एक उपयोगकर्ता-परिभाषित फॉर्म क्लास का उपयोग फ्लास्क एप्लिकेशन में किया जाता है और टेम्प्लेट का उपयोग करके फॉर्म को प्रस्तुत किया जाता है।
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)
WTForms पैकेज में सत्यापनकर्ता वर्ग भी होता है। फ़ील्ड बनाने के लिए सत्यापन लागू करने में उपयोगी है। निम्नलिखित सूची आमतौर पर इस्तेमाल किए गए सत्यापनकर्ताओं को दिखाती है।
अनु क्रमांक | सत्यापनकर्ता वर्ग और विवरण |
---|---|
1 | DataRequired जाँचता है कि इनपुट फ़ील्ड खाली है या नहीं |
2 | जाँचता है कि क्या फ़ील्ड में पाठ ईमेल आईडी सम्मेलनों का अनुसरण करता है |
3 | IPAddress इनपुट क्षेत्र में आईपी पते को मान्य करता है |
4 | Length सत्यापित करता है कि इनपुट क्षेत्र में स्ट्रिंग की लंबाई दी गई सीमा में है |
5 | NumberRange दिए गए सीमा के भीतर इनपुट क्षेत्र में एक संख्या को मान्य करता है |
6 | URL URL इनपुट क्षेत्र में दर्ज किया गया |
अब हम आवेदन करेंगे ‘DataRequired’ के लिए सत्यापन नियम name संपर्क फ़ॉर्म में फ़ील्ड।
name = TextField("Name Of Student",[validators.Required("Please enter your name.")])
validate()प्रपत्र ऑब्जेक्ट का फ़ंक्शन प्रपत्र डेटा को मान्य करता है और सत्यापन विफल हो जाता है यदि सत्यापन विफल हो जाता है। Errorसंदेश टेम्प्लेट में भेजे जाते हैं। HTML टेम्पलेट में, त्रुटि संदेश गतिशील रूप से प्रदान किए जाते हैं।
{% for message in form.name.errors %}
{{ message }}
{% endfor %}
निम्नलिखित उदाहरण ऊपर दी गई अवधारणाओं को प्रदर्शित करता है। का डिजाइनContact form नीचे दिया गया है (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")
मान्यताओं को लागू किया जाता है Name तथा Email खेत।
नीचे दिए गए फ्लास्क एप्लिकेशन स्क्रिप्ट है (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)
टेम्पलेट की स्क्रिप्ट (contact.html) इस प्रकार है -
<!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>
Daud formexample.py पायथन शेल और URL पर जाएं http://localhost:5000/contact। Contact नीचे दिखाए अनुसार फॉर्म प्रदर्शित किया जाएगा।
यदि कोई त्रुटि है, तो पृष्ठ इस तरह दिखेगा -
यदि कोई त्रुटि नहीं है, ‘success.html’ प्रदान किया जाएगा।