首頁 > 後端開發 > Python教學 > 使用Python3製作TCP埠掃描器的圖文程式碼詳解

使用Python3製作TCP埠掃描器的圖文程式碼詳解

黄舟
發布: 2017-04-18 10:01:39
原創
2331 人瀏覽過

本文給大家分享的是使用Python3 實現TCP全連接埠掃描器的製作過程,包括思路和程式碼,非常簡單易懂,推薦給大家

在滲透測試的初步階段通常我們都需要對攻擊目標進行資訊蒐集,而連接埠掃描就是資訊蒐集中至關重要的一個步驟。透過連接埠掃描我們可以了解到目標主機都開放了哪些服務,甚至能根據服務猜測可能存在某些漏洞。 TCP連接埠掃描一般分為以下幾種類型:

TCP connect掃描:也稱為全連接掃描,這種方式直接連接到目標端口,完成了TCP三次握手的過程,這種方式掃描結果比較準確,但速度比較慢而且可輕易被目標系統偵測到。

TCP SYN掃描:也稱為半開放掃描,這種方式將發送一個SYN包,啟動一個TCP會話,並等待目標回應資料包。如果收到的是一個RST包,則表示連接埠是關閉的,而如果收到的是一個SYN/ACK包,則表示對應的連接埠是開啟的。

Tcp FIN掃描:這種方式發送一個表示拆除一個活動的TCP連接的FIN包,讓對方關閉連線。如果收到了一個RST包,則表示對應的連接埠是關閉的。

TCP XMAS掃描:這種方式透過發送PSH、FIN、URG、和TCP標誌位元被設為1的資料包。如果收到了一個RST包,則表示對應的連接埠是關閉的。

下面我們將使用Python3 實作TCP全連接埠掃描器,以下進入程式環節。

編碼實戰

全連接掃描方式的核心就是針對不同連接埠進行TCP連接,根據是否連接成功來判斷連接埠是否打開,現在我們來實作一個最簡單的連接埠掃描器:

#!/usr/bin/python3
# -*- coding: utf-8 -*-
from socket import *

def portScanner(host,port):
  try:
    s = socket(AF_INET,SOCK_STREAM)
    s.connect((host,port))
    print('[+] %d open' % port)
    s.close()
  except:
    print('[-] %d close' % port)

def main():
  setdefaulttimeout(1)
  for p in range(1,1024):
    portScanner('192.168.0.100',p)

if name == 'main':
  main()
登入後複製

這段程式碼的核心就是portScanner函數,從其中的內容可以看出,只是進行了簡單的TCP連接,如果連接成功則判斷為連接埠打開,否則視為關閉。 讓我們來看看運行結果:

這樣的掃描看起來效率太低了,實際上確實很慢,因為我們設定了預設的超時時間為1秒,這要是掃描10,000個端口,豈不是要等到花都謝了? 最簡單的辦法就是用多執行緒來提高效率,雖然python的多執行緒有點太弱了,不過至少可以利用我們等待的時間去幹點別的。另外之前掃描的連接埠比較多, 顯示的資訊我們看起來不方便,這次我們只顯示我們關心的打開的連接埠,並將開啟連接埠的數量在掃描結束的時候顯示出來。

#!/usr/bin/python3
# -*- coding: utf-8 -*-
from socket import *
import threading

lock = threading.Lock()
openNum = 0
threads = []

def portScanner(host,port):
  global openNum
  try:
    s = socket(AF_INET,SOCK_STREAM)
    s.connect((host,port))
    lock.acquire()
    openNum+=1
    print('[+] %d open' % port)
    lock.release()
    s.close()
  except:
    pass

def main():
  setdefaulttimeout(1)
  for p in range(1,1024):
    t = threading.Thread(target=portScanner,args=('192.168.0.100',p))
    threads.append(t)
    t.start()   

  for t in threads:
    t.join()

  print('[*] The scan is complete!')
  print('[*] A total of %d open port ' % (openNum))

if name == 'main':
  main()
登入後複製

運行看一下效果,如下圖:

#這下看起來是不是方便多了?至此效率上的問題解決了,現在我們還需要為掃描器增加一個 參數解析的功能,這樣才能看起來像個樣子,總不能每次都改代碼來修改掃描目標和端口吧!

參數解析我們將用python3自帶的標準模組argparse,這樣我們就省去了自己解析字串的麻煩! 下面來看程式碼:

#!/usr/bin/python3
# -*- coding: utf-8 -*-
from socket import *
import threading
import argparse

lock = threading.Lock()
openNum = 0
threads = []

def portScanner(host,port):
  global openNum
  try:
    s = socket(AF_INET,SOCK_STREAM)
    s.connect((host,port))
    lock.acquire()
    openNum+=1
    print('[+] %d open' % port)
    lock.release()
    s.close()
  except:
    pass

def main():
  p = argparse.ArgumentParser(description='Port scanner!.')
  p.add_argument('-H', dest='hosts', type=str)
  args = p.parse_args()
  hostList = args.hosts.split(',')
  setdefaulttimeout(1)
  for host in hostList:
    print('Scanning the host:%s......' % (host))
    for p in range(1,1024):
      t = threading.Thread(target=portScanner,args=(host,p))
      threads.append(t)
      t.start()   

    for t in threads:
      t.join()

    print('[*] The host:%s scan is complete!' % (host))
    print('[*] A total of %d open port ' % (openNum))

if name == 'main':
  main()
登入後複製

看一下運行效果,如下圖:

#至此我們的連接埠掃描器就基本完成了,雖然功能比較簡單,旨在表達連接埠掃描器的基本實現思路! 至於更詳細的功能可以基於這個基本結構來逐步完善!

小結

本節主要講解了Python3實作一個簡單的連接埠掃描器的過程,本次實驗採用了Tcp全連接的方式,不斷嘗試連接主機的連接埠來判斷連接埠的開放情況,雖然存在一些缺點, 不過這種方式最適合初學者學習,至於更複雜的方式以後學習起來也不會很難。想舉一反三的朋友可以根據協議和端口的對照關係來完成掃描時同時輸出協議, 這樣看起來會更好一些,至於更詳細的功能就留給大家做練習了!

以上是使用Python3製作TCP埠掃描器的圖文程式碼詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板