我們都知道什麼是埠,以及它們是如何與網址相關聯的,但我們中的許多人可能從未聽說過埠掃描儀。基本上,埠掃描器是一個應用,設計用於探測與特定埠連接的主機或伺服器,它用於開放埠的伺服器和主機。從最後一行,我們還可以得出結論,沒有特殊許可,我們不能在關閉的埠上使用埠掃描程序應用,未經許可對關閉的埠執行掃描是非法的。管理官員通常使用埠掃描儀來驗證他們自己網路的安全策略,以檢查這些網路如何識別攻擊者或各種威脅。
注意:開放埠是指不需要主機特別許可就可以使用埠掃描程序檢查其伺服器或埠的埠。
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-tw/n/129047.html