TurboGears - मान्यता

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

ToscaWidgets Forms लाइब्रेरी के शुरुआती संस्करणों का उपयोग सत्यापन समर्थन के लिए FormEncode मॉड्यूल पर भरोसा करने के लिए किया जाता है। ToscaWidgets2 में अब tw2.core मॉड्यूल में उपलब्ध सत्यापन समर्थन उपलब्ध है। हालाँकि, अभी भी FormEncode सत्यापन तकनीकों का उपयोग करना संभव है।

ToscaWidgets फॉर्म को सत्यापन के अधीन करने के लिए, @validate डेकोरेटर का उपयोग किया जाता है।

@validate(form, error_handler, validators)
  • ’form’ ToscaWidgets फॉर्म ऑब्जेक्ट को मान्य किया जाता है।

  • ‘error-handler’ प्रपत्र त्रुटियों को संभालने के लिए उपयोग की जाने वाली नियंत्रक विधि है।

  • ‘validators’ एक डिक्शनरी ऑब्जेक्ट है जिसमें फॉर्मनकोड सत्यापनकर्ता हैं।

Validators के प्रकार

Tw2.core मॉड्यूल में एक सत्यापनकर्ता वर्ग होता है जिसमें से अन्य सत्यापनकर्ता विरासत में मिलते हैं। इसके आधार पर एक कस्टम सत्यापनकर्ता डिजाइन करना भी संभव है। कुछ महत्वपूर्ण मान्यताओं का वर्णन नीचे दिया गया है -

LengthValidator- जांचें कि क्या एक मान निर्धारित लंबाई है। न्यूनतम और अधिकतम सीमाएं न्यूनतम और अधिकतम मापदंडों के साथ परिभाषित की जाती हैं। न्यूनतम से नीचे और ऊपर की लंबाई के लिए कस्टम संदेश अधिकतम और टोशॉर्ट और टूलॉंग पैरामीटर के रूप में निर्दिष्ट किए जा सकते हैं।

tw2.core.LengthValidator(min = minval, max = maxval, 
   msgs = { 'tooshort': (‘message for short length’), 
   'toolong': (‘message for long length)})

RangeValidator- आमतौर पर रेंजफिल्ड के साथ उपयोग किया जाता है। यह न्यूनतम और अधिकतम सीमाओं के भीतर एक संख्यात्मक क्षेत्र के मूल्य को मान्य करने के लिए उपयोगी है। तोशॉर्ट और टूलॉन्ग मापदंडों के लिए संदेश अनुकूलित किए जा सकते हैं।

tw2.core.RangeValidator(min = minval, max = maxval, 
   msgs = { 'tooshort': (‘message for short length’), 
   'toolong': (‘message for long length)})

IntValidator- यह वर्ग RangeValidator से लिया गया है। यह सामान्य रूप से मान्य करने के लिए उपयोग किया जाता है यदि सामान्य पाठ फ़ील्ड में इनपुट पूर्णांक डेटा युक्त है। न्यूनतम और अधिकतम सीमा और साथ ही त्रुटि संदेश भी सेट किए जा सकते हैं। इसके अतिरिक्त, गैर-पूर्णांक इनपुट के लिए त्रुटि संदेश को 'notint' पैरामीटर के रूप में निर्दिष्ट किया जा सकता है।

tw2.core.IntValidator(msgs = {‘notint’:’Must be Integer’})

OneOfValidator - यह सत्यापनकर्ता उपयोगकर्ता को केवल सूची में उपलब्ध विकल्पों में से एक मूल्य का चयन करने के लिए मजबूर करता है।

tw2.core.OneOfValidator(values = [option1, option2,..], 
   msgs = {‘notinlist’:’Not in List’}}

DateValidator- यह सुनिश्चित करने के लिए बहुत उपयोगी है कि उपयोगकर्ता इनपुट एक वैध तिथि है। दिनांक प्रारूप (डिफ़ॉल्ट YMD है) और त्रुटि संदेश अनुकूलन योग्य हैं। न्यूनतम और अधिकतम तिथि सीमा भी निर्दिष्ट की जा सकती है। DateTimeValidator, DateTime वर्ग की वस्तु को सत्यापित करने के लिए भी उपलब्ध है।

tw2.core.DateValidator(msgs = {format = ’%Y-%m-%d’, 
   'baddatetime': ('baddate', ('Must follow date format $format_str'))}

EmailValidator- मान्य ईमेल पते के खिलाफ उपयोगकर्ता इनपुट को मान्य करता है। यह वर्ग एक अधिक सामान्य RegexValidator से विरासत में मिला है।

tw2.core.EmailValidator(msgs = {'badregex': ('bademail', 
   ('Must be a valid email address')) }

UrlValidator- यह वर्ग भी RegexValidator से विरासत में मिला है। यह मान्य URL के लिए उपयोगकर्ता इनपुट को मान्य करता है।

tw2.core.UrlValidator(msgs = {'badregex': ('badurl', ('Must be a valid URL’)) }

MatchValidator- पुष्टि करता है कि एक क्षेत्र का मूल्य दूसरे के साथ मेल खाता है या नहीं। यह विशेष रूप से उपयोगी है, जहां उपयोगकर्ता को पासवर्ड फ़ील्ड चुनने और पुष्टि करने की आवश्यकता होती है। माचिसवैलिलेटर का विशिष्ट उपयोग नीचे दिखाया गया है -

import tw2.core as twc
import tw2.forms as twf
  
  class AdmissionForm(twf.Form):
      class child(twf.TableLayout):
         validator = twc.MatchValidator('pw', 'pwconfirm')
         pw = twf.PasswordField()
         pwconfirm = twf.PasswordField()

एक यौगिक सत्यापनकर्ता का निर्माण करना भी संभव है, जहां सत्यापन सफल होता है, यदि कोई भी चेक पास करता है। अन्य मामलों में, आप सत्यापन को सफल होने के लिए चाहते हो सकता है, केवल तभी जब इनपुट सभी चेक पास करता है। इसके लिए, tw2.core एनी और ऑल वेरिडेटर्स प्रदान करता है, जो कि एक्सपेंडेबल कंपाउंडवैलिडेटर के उपवर्ग हैं।