पायथन नेटवर्क स्कैनर
पोर्ट स्कैनिंग को एक निगरानी तकनीक के रूप में परिभाषित किया जा सकता है, जिसका उपयोग किसी विशेष होस्ट पर उपलब्ध खुले पोर्ट का पता लगाने के लिए किया जाता है। नेटवर्क व्यवस्थापक, पैठ परीक्षक या हैकर इस तकनीक का उपयोग कर सकते हैं। हम लक्ष्य प्रणाली से अधिकतम जानकारी प्राप्त करने के लिए अपनी आवश्यकताओं के अनुसार पोर्ट स्कैनर को कॉन्फ़िगर कर सकते हैं।
अब, पोर्ट स्कैन को चलाने के बाद मिलने वाली जानकारी पर विचार करें -
खुले बंदरगाहों के बारे में जानकारी।
प्रत्येक पोर्ट पर चलने वाली सेवाओं के बारे में जानकारी।
लक्ष्य होस्ट के ओएस और मैक पते के बारे में जानकारी।
पोर्ट स्कैनिंग एक चोर की तरह है, जो हर दरवाजे और खिड़की की जांच करके एक घर में प्रवेश करना चाहता है, जो कि खुले हैं। जैसा कि पहले चर्चा की गई, टीसीपी / आईपी प्रोटोकॉल सूट, इंटरनेट पर संचार के लिए उपयोग, दो प्रोटोकॉल टीसीपी और यूडीपी से बना है। दोनों प्रोटोकॉल में 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