Django - फार्म प्रसंस्करण

Django में फॉर्म बनाना, वास्तव में एक मॉडल बनाने के समान है। यहाँ फिर से, हमें केवल Django वर्ग से विरासत में लेने की आवश्यकता है और वर्ग के रूप फॉर्म फ़ील्ड होंगे। चलो एक जोड़ते हैंforms.pyहमारे ऐप फ़ॉर्म को सम्‍मिलित करने के लिए myapp फ़ोल्डर में फ़ाइल करें। हम एक लॉगिन फॉर्म बनाएंगे।

myapp/forms.py

#-*- coding: utf-8 -*-
from django import forms

class LoginForm(forms.Form):
   user = forms.CharField(max_length = 100)
   password = forms.CharField(widget = forms.PasswordInput())

जैसा कि ऊपर देखा गया है, HTML प्रतिपादन के लिए फ़ील्ड प्रकार "विजेट" तर्क ले सकता है; हमारे मामले में, हम चाहते हैं कि पासवर्ड छिपा हो, प्रदर्शित न हो। कई अन्य विजेट Django में मौजूद हैं:DateInput दिनांक के लिए, CheckboxInput चेकबॉक्स के लिए, आदि।

एक दृश्य में फ़ॉर्म का उपयोग करना

दो प्रकार के HTTP अनुरोध, GET और POST हैं। Django में, आपके दृष्टिकोण के पैरामीटर के रूप में पारित अनुरोध ऑब्जेक्ट में "विधि" नामक एक विशेषता है जहां अनुरोध का प्रकार सेट किया गया है, और POST के माध्यम से पारित किए गए सभी डेटा को request.POST शब्दकोश के माध्यम से एक्सेस किया जा सकता है।

आइए हमारे myapp / views.py में लॉगिन दृश्य बनाएं -

#-*- coding: utf-8 -*-
from myapp.forms import LoginForm

def login(request):
   username = "not logged in"
   
   if request.method == "POST":
      #Get the posted form
      MyLoginForm = LoginForm(request.POST)
      
      if MyLoginForm.is_valid():
         username = MyLoginForm.cleaned_data['username']
   else:
      MyLoginForm = Loginform()
		
   return render(request, 'loggedin.html', {"username" : username})

दृश्य के माध्यम से पोस्ट किए गए लॉगिन फ़ॉर्म का परिणाम प्रदर्शित करेगा loggedin.html। इसका परीक्षण करने के लिए, हमें पहले लॉगिन फॉर्म टेम्पलेट की आवश्यकता होगी। इसे login.html कहते हैं।

<html>
   <body>
      
      <form name = "form" action = "{% url "myapp.views.login" %}" 
         method = "POST" >{% csrf_token %}
         
         <div style = "max-width:470px;">
            <center> 
               <input type = "text" style = "margin-left:20%;" 
                  placeholder = "Identifiant" name = "username" />
            </center>
         </div>
			
         <br>
         
         <div style = "max-width:470px;">
            <center>
               <input type = "password" style = "margin-left:20%;" 
                  placeholder = "password" name = "password" />
            </center>
         </div>
			
         <br>
         
         <div style = "max-width:470px;">
            <center> 
            
               <button style = "border:0px; background-color:#4285F4; margin-top:8%;
                  height:35px; width:80%;margin-left:19%;" type = "submit" 
                  value = "Login" >
                  <strong>Login</strong>
               </button>
               
            </center>
         </div>
         
      </form>
      
   </body>
</html>

टेम्पलेट एक लॉगिन फ़ॉर्म प्रदर्शित करेगा और परिणाम को हमारे लॉगिन दृश्य के ऊपर पोस्ट करेगा। आपने शायद टेम्प्लेट में टैग देखा है, जो कि आपकी साइट पर क्रॉस-साइट रिक्वेस्ट फॉरगेरी (CSRF) हमले को रोकने के लिए है।

{% csrf_token %}

एक बार हमारे पास लॉगिन टेम्प्लेट होने के बाद, हमें login.html टेम्प्लेट की आवश्यकता होती है, जिसे फॉर्म उपचार के बाद प्रदान किया जाएगा।

<html>
   
   <body>
      You are : <strong>{{username}}</strong>
   </body>
   
</html>

अब, हमें आरंभ करने के लिए बस अपनी जोड़ी के URL की आवश्यकता है: myapp / urls.py

from django.conf.urls import patterns, url
from django.views.generic import TemplateView

urlpatterns = patterns('myapp.views',
   url(r'^connection/',TemplateView.as_view(template_name = 'login.html')),
   url(r'^login/', 'login', name = 'login'))

"/ Myapp / कनेक्शन" एक्सेस करते समय, हम निम्नलिखित login.html टेम्पलेट प्रदान करेंगे -

फॉर्म पोस्ट पर, फॉर्म वैध है। हमारे मामले में दो क्षेत्रों को भरना सुनिश्चित करें और आपको मिलेगा -

यदि आपका उपयोगकर्ता नाम पोलो है, और आप पासवर्ड भूल गए हैं। आपको निम्न संदेश मिलेगा -

हमारी खुद की मान्यता का उपयोग करना

उपरोक्त उदाहरण में, जब फॉर्म को मान्य किया जाता है -

MyLoginForm.is_valid()

हमने केवल Django स्व-फॉर्म सत्यापन इंजन का उपयोग किया है, हमारे मामले में सिर्फ यह सुनिश्चित करने के लिए कि खेतों की आवश्यकता है। अब चलो यह सुनिश्चित करने का प्रयास करें कि लॉगिन करने का प्रयास करने वाला उपयोगकर्ता हमारे DB में Dreamreal प्रविष्टि के रूप में मौजूद है। इसके लिए, myapp / form.py को बदल कर -

#-*- coding: utf-8 -*-
from django import forms
from myapp.models import Dreamreal

class LoginForm(forms.Form):
   user = forms.CharField(max_length = 100)
   password = forms.CharField(widget = forms.PasswordInput())

   def clean_message(self):
      username = self.cleaned_data.get("username")
      dbuser = Dreamreal.objects.filter(name = username)
      
      if not dbuser:
         raise forms.ValidationError("User does not exist in our db!")
      return username

अब, "is_valid" विधि को कॉल करने के बाद, हम सही आउटपुट प्राप्त करेंगे, केवल अगर उपयोगकर्ता हमारे डेटाबेस में है। यदि आप अपने फॉर्म के एक क्षेत्र की जांच करना चाहते हैं, तो बस "clean_" द्वारा शुरू करने वाली एक विधि जोड़ें, फिर आपके फ़ील्ड का नाम आपके फॉर्म वर्ग के लिए। एक फ़ॉर्म को उठाना। अमान्यकरण महत्वपूर्ण है।