नेटवर्क पैकेट सूँघना
सूँघना या नेटवर्क पैकेट सूँघना सूँघने के औज़ारों का उपयोग करके किसी दिए गए नेटवर्क से गुजरने वाले सभी पैकेटों की निगरानी और उन्हें पकड़ने की प्रक्रिया है। यह एक ऐसा रूप है, जिसमें हम "फोन तारों को टैप" कर सकते हैं और बातचीत को जान सकते हैं। इसे कहते भी हैंwiretapping और कंप्यूटर नेटवर्क पर लागू किया जा सकता है।
इतनी संभावना है कि यदि उद्यम स्विच पोर्ट का एक सेट खुला है, तो उनका एक कर्मचारी नेटवर्क के पूरे ट्रैफ़िक को सूँघ सकता है। समान भौतिक स्थान में कोई भी ईथरनेट केबल का उपयोग करके नेटवर्क में प्लग कर सकता है या वायरलेस से उस नेटवर्क से जुड़ सकता है और कुल ट्रैफ़िक को सूँघ सकता है।
दूसरे शब्दों में, सूँघने से आप संरक्षित और असुरक्षित दोनों तरह के यातायात देख सकते हैं। सही परिस्थितियों में और सही प्रोटोकॉल के साथ, एक हमलावर पार्टी ऐसी जानकारी एकत्र करने में सक्षम हो सकती है जो आगे के हमलों के लिए या नेटवर्क या सिस्टम के मालिक के लिए अन्य मुद्दों का कारण बन सकती है।
क्या सूँघा जा सकता है?
एक नेटवर्क से निम्नलिखित संवेदनशील जानकारी सूँघ सकता है -
- ईमेल ट्रैफ़िक
- एफ़टीपी पासवर्ड
- वेब ट्रैफ़िक
- टेलनेट पासवर्ड
- राउटर कॉन्फ़िगरेशन
- चैट सत्र
- डीएनएस यातायात
सूँघने का काम कैसे करता है?
एक स्निफर सामान्य रूप से सिस्टम के एनआईसी को प्रोमिसस मोड में बदल देता है ताकि वह अपने सेगमेंट पर प्रसारित सभी डेटा को सुन सके।
विशिष्ट मोड ईथरनेट हार्डवेयर के अनूठे तरीके को संदर्भित करता है, विशेष रूप से, नेटवर्क इंटरफ़ेस कार्ड (एनआईसी), जो एनआईसी को नेटवर्क पर सभी ट्रैफ़िक प्राप्त करने की अनुमति देता है, भले ही वह इस एनआईसी को संबोधित न हो। डिफ़ॉल्ट रूप से, एक एनआईसी सभी ट्रैफ़िक को अनदेखा करता है जो इसे संबोधित नहीं करता है, जो डिवाइस के हार्डवेयर पते (मैक) के साथ ईथरनेट पैकेट के गंतव्य पते की तुलना करके किया जाता है। हालांकि यह नेटवर्किंग के लिए एकदम सही समझ में आता है, गैर-विवादास्पद मोड कनेक्टिविटी मुद्दों या ट्रैफ़िक लेखांकन के निदान के लिए नेटवर्क निगरानी और विश्लेषण सॉफ़्टवेयर का उपयोग करना मुश्किल बनाता है।
एक स्निफर डेटा पैकेट में दर्ज जानकारी को डीकोड करके एनआईसी के माध्यम से कंप्यूटर पर सभी ट्रैफ़िक की लगातार निगरानी कर सकता है।
सूँघने का प्रकार
सूँघना या तो सक्रिय या स्वभाव में निष्क्रिय हो सकता है। अब हम विभिन्न प्रकार के सूँघने के बारे में जानेंगे।
निष्क्रिय सूँघना
निष्क्रिय सूँघने में, यातायात बंद है लेकिन इसे किसी भी तरह से बदला नहीं जाता है। निष्क्रिय सूँघने से केवल सुनने की अनुमति मिलती है। यह हब उपकरणों के साथ काम करता है। हब डिवाइस पर, ट्रैफ़िक को सभी पोर्ट पर भेजा जाता है। सिस्टम को जोड़ने के लिए हब का उपयोग करने वाले नेटवर्क में, नेटवर्क पर सभी होस्ट ट्रैफ़िक देख सकते हैं। इसलिए, एक हमलावर आसानी से गुजरने वाले ट्रैफ़िक को पकड़ सकता है।
अच्छी खबर यह है कि हाल के दिनों में हब लगभग अप्रचलित हो गए हैं। अधिकांश आधुनिक नेटवर्क स्विच का उपयोग करते हैं। इसलिए, निष्क्रिय सूँघना अधिक प्रभावी नहीं है।
सक्रिय सूँघना
सक्रिय सूँघने में, ट्रैफ़िक को न केवल लॉक और मॉनिटर किया जाता है, बल्कि इसे किसी तरह से बदल दिया जा सकता है जैसा कि हमले द्वारा निर्धारित किया गया है। स्विच-आधारित नेटवर्क को सूँघने के लिए सक्रिय सूँघने का उपयोग किया जाता है। इसमें स्विच रिज़ॉल्यूशन एड्रेसेबल मेमोरी (CAM) टेबल पर बाढ़ के लिए एड्रेस रिज़ॉल्यूशन पैकेट (ARP) को एक लक्ष्य नेटवर्क में इंजेक्ट करना शामिल है। CAM किस पोर्ट से जुड़ा है, इसका ट्रैक रखता है।
निम्नलिखित सक्रिय सूँघने की तकनीकें हैं -
- मैक बाढ़
- डीएचसीपी हमलों
- डीएनएस जहर
- स्पूफिंग अटैक
- एआरपी जहर दे रहे हैं
प्रोटोकॉल पर सूँघने के प्रभाव
प्रोटोकॉल जैसे tried and true TCP/IPकभी भी सुरक्षा को ध्यान में रखकर नहीं बनाया गया। इस तरह के प्रोटोकॉल संभावित घुसपैठियों के लिए बहुत प्रतिरोध की पेशकश नहीं करते हैं। निम्नलिखित विभिन्न प्रोटोकॉल हैं जो आसान सूँघने के लिए उधार देते हैं -
एचटीटीपी
इसका उपयोग बिना किसी एन्क्रिप्शन के स्पष्ट पाठ में जानकारी भेजने और इस तरह एक वास्तविक लक्ष्य के लिए किया जाता है।
SMTP (सिंपल मेल ट्रांसफर प्रोटोकॉल)
ईमेल के हस्तांतरण में SMTP का उपयोग किया जाता है। यह प्रोटोकॉल कुशल है, लेकिन इसमें सूँघने से सुरक्षा शामिल नहीं है।
NNTP (नेटवर्क समाचार स्थानांतरण प्रोटोकॉल)
इसका उपयोग सभी प्रकार के संचार के लिए किया जाता है। इसके साथ एक बड़ी खामी यह है कि डेटा और यहां तक कि पासवर्ड भी स्पष्ट पाठ के रूप में नेटवर्क पर भेजे जाते हैं।
पीओपी (पोस्ट ऑफिस प्रोटोकॉल)
सर्वरों से ईमेल प्राप्त करने के लिए पीओपी का कड़ाई से उपयोग किया जाता है। इस प्रोटोकॉल में सूँघने से सुरक्षा शामिल नहीं है क्योंकि यह फंस सकता है।
एफ़टीपी (फ़ाइल स्थानांतरण प्रोटोकॉल)
एफ़टीपी का उपयोग फ़ाइलों को भेजने और प्राप्त करने के लिए किया जाता है, लेकिन यह किसी भी सुरक्षा सुविधाओं की पेशकश नहीं करता है। सभी डेटा को स्पष्ट पाठ के रूप में भेजा जाता है जिसे आसानी से सूँघा जा सकता है।
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])
इसी तरह, हम टीसीपी हेडर को पार्स भी कर सकते हैं।