python實現(xiàn)多線程端口掃描
一個簡易的TCP端口掃描器,使用python3實現(xiàn)。
需求:掃描目標網(wǎng)站開放哪些端口號,將所有開放的端口號輸出。
分析:使用socket連接,如果連接成功,認為端口開放,如果連接失敗,認為端口關(guān)閉(有可能端口開放但連接失敗,這里簡單認為端口不開放)
使用到的庫:socket, threading
過程:
先定義一個函數(shù),對給定的(ip, port)進行掃描,看其是否能連接成功。
def tcpPortScan(ip, port, openPort): sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 創(chuàng)建套接字 sock.settimeout(0.1) # 設(shè)置延時時間 try: result = sock.connect_ex((ip, port)) if result == 0: # 如果連接成功,返回值為0 openPort.append(port) # 如果端口開放,就把端口port賦給openPort except: pass sock.close() # 關(guān)閉套接字
當需要掃描目標地址的多個端口時,循環(huán)使用上述函數(shù)的話,掃描速度會極其慢,因為考慮使用多線程。
再定義一個函數(shù),實現(xiàn)多線程掃描。
def threadingPortScan(host, portList, openPorts = []): hostIP = socket.gethostbyname(host) # 獲取域名對應(yīng)的IP地址 nloops = range(len(portList)) threads = [] for i in nloops: t = threading.Thread(target=tcpPortScan, args=(hostIP, portList[i], openPorts)) threads.append(t) for i in nloops: threads[i].start() for i in nloops: threads[i].join() return openPorts # 返回值為該域名下開放的端口列表
完整代碼如下:
# -*- coding:utf-8 -*-
'''
使用多線程,檢測一個目標地址的端口開放情況,目標地址由用戶輸入,端口暫時定義為0~1024,
檢測TCP連接是否成功,如果連接成功,則端口開放,不成功則端口關(guān)閉
'''
import socket
import threading
def main():
host = input('please input domain:')
portList = range(0, 1025)
openPorts = threadingPortScan(host, portList)
print(host,'open ports:', openPorts)
# 對給定的(ip, port)進行TCP連接掃描
def tcpPortScan(ip, port, openPort):
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 創(chuàng)建套接字
sock.settimeout(0.1) # 設(shè)置延時時間
try:
result = sock.connect_ex((ip, port))
if result == 0:
openPort.append(port) # 如果端口開放,就把端口port賦給openPort
except:
pass
sock.close() # 關(guān)閉套接字
def threadingPortScan(host, portList, openPorts = []):
hostIP = socket.gethostbyname(host) # 獲取域名對應(yīng)的IP地址
nloops = range(len(portList))
threads = []
for i in nloops:
t = threading.Thread(target=tcpPortScan, args=(hostIP, portList[i], openPorts))
threads.append(t)
for i in nloops:
threads[i].start()
for i in nloops:
threads[i].join()
return openPorts # 返回值為該域名下開放的端口列表
if __name__ == '__main__':
main()
使用www.qq.com做一個測試,測試結(jié)果如下:
>>>please input domain: www.qq.com www.qq.com open ports: [80, 843]
總結(jié):這個小程序僅適用于新手練習(xí),不適合真正應(yīng)用。該簡易端口掃描器僅能掃描出一部分端口,有些端口可能因為防火墻攔截導(dǎo)致掃描失敗。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于numpy中eye和identity的區(qū)別詳解
今天小編就為大家分享一篇關(guān)于numpy中eye和identity的區(qū)別詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11
Python實現(xiàn)批量轉(zhuǎn)換文件編碼的方法
這篇文章主要介紹了Python實現(xiàn)批量轉(zhuǎn)換文件編碼的方法,涉及Python針對文件的遍歷及編碼轉(zhuǎn)換實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-07-07

