क्लाइंट-साइड वैलिडेशन
इस अध्याय में, हम यह जानेंगे कि पायथन पेंटिग में सत्यापन कैसे मदद करता है।
सत्यापन का मुख्य लक्ष्य परीक्षण करना और यह सुनिश्चित करना है कि उपयोगकर्ता ने एक ऑपरेशन को सफलतापूर्वक पूरा करने के लिए आवश्यक और ठीक से स्वरूपित जानकारी प्रदान की है।
सत्यापन के दो प्रकार हैं -
- क्लाइंट-साइड सत्यापन (वेब ब्राउज़र)
- सर्वर-साइड सत्यापन
सर्वर-साइड वैलिडेशन और क्लाइंट-साइड वैलिडेशन
पोस्ट बैक सेशन के दौरान सर्वर साइड पर होने वाले यूजर इनपुट वेलिडेशन को कहा जाता है server-side validation। PHP और ASP.Net जैसी भाषाएं सर्वर-साइड सत्यापन का उपयोग करती हैं। सर्वर साइड पर सत्यापन की प्रक्रिया समाप्त होने के बाद, एक नया और गतिशील वेब पेज बनाकर फीडबैक क्लाइंट को वापस भेजा जाता है। सर्वर-साइड सत्यापन की मदद से, हम दुर्भावनापूर्ण उपयोगकर्ताओं के खिलाफ सुरक्षा प्राप्त कर सकते हैं।
दूसरी ओर, ग्राहक पक्ष पर होने वाले उपयोगकर्ता इनपुट सत्यापन को क्लाइंट-साइड सत्यापन कहा जाता है। जावास्क्रिप्ट और VBScript जैसी स्क्रिप्टिंग भाषाओं के लिए उपयोग किया जाता हैclient-side validation। इस तरह के सत्यापन में, सभी उपयोगकर्ता इनपुट सत्यापन उपयोगकर्ता के ब्राउज़र में ही किए जाते हैं। यह सर्वर-साइड सत्यापन की तरह सुरक्षित नहीं है क्योंकि हैकर आसानी से हमारी क्लाइंट साइड स्क्रिप्टिंग भाषा को दरकिनार कर सकता है और सर्वर को खतरनाक इनपुट सबमिट कर सकता है।
टेम्परिंग क्लाइंट-साइड पैरामीटर: सत्यापन बायपास
HTTP प्रोटोकॉल में पासिंग को POST और GET के तरीकों की मदद से किया जा सकता है। GET का उपयोग किसी निर्दिष्ट संसाधन से डेटा का अनुरोध करने के लिए किया जाता है और POST का उपयोग किसी संसाधन को बनाने या अपडेट करने के लिए सर्वर को डेटा भेजने के लिए किया जाता है। इन दोनों विधियों के बीच एक बड़ा अंतर यह है कि यदि कोई वेबसाइट GET पद्धति का उपयोग कर रही है तो URL में पासिंग पैरामीटर दिखाए जाते हैं और हम इस पैरामीटर को बदल सकते हैं और इसे वेब सर्वर को पास कर सकते हैं। उदाहरण के लिए, क्वेरी स्ट्रिंग (नाम / मान जोड़े) एक GET अनुरोध के URL में भेजा गया है:/test/hello_form.php?name1 = value1&name2 = value2। दूसरी ओर, POST विधि का उपयोग करते समय पैरामीटर नहीं दिखाए जाते हैं। POST के साथ सर्वर को भेजा गया डेटा HTTP अनुरोध के अनुरोध निकाय में संग्रहीत है। उदाहरण के लिए, POST/test/hello_form.php HTTP/1.1 Host: ‘URL’ name1 = value1&name2 = value2।
वैलिडेशन बायपास के लिए पायथन मॉड्यूल
पायथन मॉड्यूल जो हम उपयोग करने जा रहे हैं वह है mechanize। यह एक पायथन वेब ब्राउज़र है, जो एक वेब पेज में वेब फॉर्म प्राप्त करने की सुविधा प्रदान करता है और इनपुट मानों को जमा करने की सुविधा भी प्रदान करता है। मशीनीकरण की मदद से, हम सत्यापन और टेम्पर्ड क्लाइंट-साइड मापदंडों को बायपास कर सकते हैं। हालाँकि, इसे हमारे पाइथन लिपि में आयात करने से पहले, हमें निम्नलिखित कमांड निष्पादित करके इसे स्थापित करने की आवश्यकता है -
pip install mechanize
उदाहरण
निम्नलिखित एक पायथन स्क्रिप्ट है, जो पैरामीटर पारित करने के लिए POST विधि का उपयोग करके वेब फॉर्म की मान्यता को बायपास करने के लिए मैकेनाइज का उपयोग करता है। वेब फॉर्म लिंक से लिया जा सकता हैhttps://www.tutorialspoint.com/php/php_validation_example.htm और अपनी पसंद के किसी भी डमी वेबसाइट में इस्तेमाल किया जा सकता है।
शुरू करने के लिए, आइए हम मशीनी ब्राउज़र आयात करें -
import mechanize
अब, हम नाम की एक वस्तु बनाएंगे brwsr मशीनी ब्राउज़र का -
brwsr = mechanize.Browser()
कोड की अगली पंक्ति से पता चलता है कि उपयोगकर्ता एजेंट रोबोट नहीं है।
brwsr.set_handle_robots( False )
अब, हमें अपनी डमी वेबसाइट का url प्रदान करना होगा जिसमें वेब फॉर्म होगा जिस पर हमें सत्यापन को बायपास करना होगा।
url = input("Enter URL ")
अब, निम्नलिखित पंक्तियाँ कुछ पैरेंट को सही पर सेट करेंगी।
brwsr.set_handle_equiv(True)
brwsr.set_handle_gzip(True)
brwsr.set_handle_redirect(True)
brwsr.set_handle_referer(True)
इसके बाद वेब पेज खुलेगा और उस पेज पर वेब फॉर्म प्रिंट होगा।
brwsr.open(url)
for form in brwsr.forms():
print form
कोड की अगली पंक्ति दिए गए फ़ील्ड पर मान्यताओं को दरकिनार कर देगी।
brwsr.select_form(nr = 0)
brwsr.form['name'] = ''
brwsr.form['gender'] = ''
brwsr.submit()
स्क्रिप्ट के अंतिम भाग को वेब फॉर्म के क्षेत्रों के अनुसार बदला जा सकता है, जिस पर हम सत्यापन को बायपास करना चाहते हैं। यहाँ उपरोक्त स्क्रिप्ट में, हमने दो फ़ील्ड लिए हैं -‘name’ तथा ‘gender’ जिसे खाली नहीं छोड़ा जा सकता (आप वेब फ़ॉर्म की कोडिंग में देख सकते हैं) लेकिन यह स्क्रिप्ट उस सत्यापन को बायपास कर देगी।