我們都知道什麼是端口,以及它們是如何與網址相關聯的,但我們中的許多人可能從未聽說過端口掃描儀。基本上,端口掃描器是一個應用,設計用於探測與特定端口連接的主機或服務器,它用於開放端口的服務器和主機。從最後一行,我們還可以得出結論,沒有特殊許可,我們不能在關閉的端口上使用端口掃描程序應用,未經許可對關閉的端口執行掃描是非法的。管理官員通常使用端口掃描儀來驗證他們自己網絡的安全策略,以檢查這些網絡如何識別攻擊者或各種威脅。
注意:開放端口是指不需要主機特別許可就可以使用端口掃描程序檢查其服務器或端口的端口。
Python 是一種多樣化的編程語言,這意味着我們幾乎可以在與技術相關的每個領域和任務中看到 Python 語言的應用。因此,我們肯定會想到一個問題,那就是我們有沒有可能用 Python 構建一個端口掃描器,還有一個問題,那就是我們能不能自己構建一個端口掃描器。我們可以構建自己的端口掃描器應用,甚至可以使用 Python 程序來實現。是的,我們可以使用 Python 程序構建一個端口掃描程序應用,我們甚至可以使用我們構建的應用掃描多個端口,這是絕對正確的。
Python 為我們提供了模塊,我們可以在 Python 程序中使用這些模塊來構建端口掃描器。我們可以在 Python 中找到的這樣的模塊之一是 nmap-python 模塊,它用於構建端口掃描器。我們將在本文中學習 Nmap 模塊,我們將通過在 Python 程序中使用該模塊來構建我們自己的端口掃描器。
Python 中的 Nmap 模塊
Nmap Module,實際名稱為 nmap-python Module,是一個開源的 python 模塊,通過使用 Python 程序創建端口掃描器,幫助我們實現端口掃描的任務。通過在 Python 程序中使用這個 Nmap Module,我們可以構建一個端口掃描器,當我們運行程序時,端口掃描器會自動檢查我們在程序內部定義的端口範圍。
Nmap: 一種免費的開源網絡掃描工具,用於創建端口掃描儀,以執行多個端口的檢查,稱為 Nmap。
Nmap 模塊:安裝
Python Nmap Module 在 Python 中並不是一個內置的模塊,如果我們想在 Python 中使用這個模塊創建一個端口掃描器,我們首先要在我們的系統中安裝它。我們可以通過多種方式在系統中安裝這個 Nmap 模塊,但是我們更喜歡使用 pip 安裝程序來完成這個任務。因此,我們將使用命令提示符終端的 pip 安裝程序在我們的設備中安裝 Nmap 模塊,以便我們可以將其導入 Python 程序。
我們將在設備的命令提示符終端中使用以下 pip installer 命令,以便在系統中安裝 Nmap Module:
pip install python-nmap
像我們一樣在 shell 中寫入命令後,我們必須按 enter 鍵開始安裝過程,並且必須等待一段時間,直到安裝過程完成。
我們可以看到,現在 Nmap 模塊的安裝過程已經完成,並且它已經成功安裝在我們的系統中。我們現在可以在 Python 程序中使用 Nmap 模塊及其功能,方法是將該模塊導入程序。
Nmap 模塊:實現
我們現在將在 Python 程序中使用這個 Nmap Module,在這個模塊中提供的函數的幫助下,我們將使用這個程序創建一個端口掃描器。由於我們已經了解到未經許可對關閉的端口進行端口掃描是非法的,因此我們將選擇 localhost (127.0.0.1)作為目標來使用端口掃描程序。在這個示例 Python 程序中,我們將給出端口掃描器中的範圍,程序將告訴我們給定範圍中的哪個端口是打開的,哪個端口是關閉的。
示例:
請看下面的示例 Python 程序,其中我們使用了 Nmap 模塊來執行本地主機(127.0.0.1)的端口掃描:
# Import Nmap Module
import nmap
# Providing range of port scanning
starting = 70
closing = 90
# Assigning target host
targetHost = '127.0.0.1'
# Using scanner from Nmap Module
portScanner = nmap.PortScanner()
# Looping over the range to check each port
for j in range(starting, closing + 1):
# Scanning the target host
resultant = portScanner.scan(targetHost, str(j))
# Storing result in the form of dictionary
resultant = resultant['scan'][targetHost]['tcp'][j]['state']
# Printing result for port
print(f'The port {j} number from the range is {resultant}.')
輸出:
The port 70 number in the range is closed.
The port 71 number in the range is closed.
The port 72 number in the range is closed.
The port 73 number in the range is closed.
The port 74 number in the range is closed.
The port 75 number in the range is closed.
The port 76 number in the range is closed.
The port 77 number in the range is closed.
The port 78 number in the range is closed.
The port 79 number in the range is closed.
The port 80 number in the range is closed.
The port 81 number in the range is closed.
The port 82 number in the range is closed.
The port 83 number in the range is closed.
The port 84 number in the range is closed.
The port 85 number in the range is closed.
The port 86 number in the range is closed.
The port 87 number in the range is closed.
The port 88 number in the range is closed.
The port 89 number in the range is closed.
The port 90 number in the range is closed.
說明:
我們首先將 Nmap 模塊導入到我們的程序中,這樣我們就可以在程序中使用端口掃描儀和其他功能。之後,我們已經定義了範圍,我們將掃描每個端口以檢查端口(來自範圍)是關閉還是打開,並且我們將對範圍中的每個端口執行此操作。之後,我們定義了執行檢查的目標主機,並初始化了『targetHost』變量以在其中打開本地主機。然後,我們使用 Nmap 模塊中的 portscanner()函數來初始化一個 scanner 變量,稍後我們將使用它來掃描目標主機。之後,我們使用 for
循環,這樣我們就可以在給定範圍內的每個端口上循環,並檢查它是關閉還是打開。在 for
循環中,首先,我們初始化了一個「resultant」變量,其中我們使用之前初始化的 scanner 變量掃描了目標主機。之後,在 for
循環中,我們再次調用結果變量來存儲結果,無論端口是關閉的還是打開的,我們使用包含多個變量的字典來生成結果。最後,我們使用 print 語句打印範圍內每個端口的結果。這個 for
循環將繼續,直到它到達範圍的終點,然後程序將被完全執行。
在輸出中,我們甚至可以看到為每個端口單獨打印結果,以檢查端口是關閉還是打開。這就是我們如何在 Python 程序中使用 Nmap 模塊來創建一個端口掃描器,並使用它掃描多個端口。
注意:為了成功運行我們將在本文中討論的程序,我們必須在我們的系統中安裝 nmap 工具,如果我們想在我們的系統中安裝該工具,我們必須參考 nmap 工具的官方網站。從官方網站上,我們可以下載 nmap 工具的安裝文件,然後我們可以在我們的系統中安裝 nmap 工具,以成功運行本文中討論的程序。
原創文章,作者:簡單一點,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/129047.html