python实现多线程端口扫描

作者:sime_km 时间:2021-07-06 03:27:26 

一个简易的TCP端口扫描器,使用python3实现。

需求:扫描目标网站开放哪些端口号,将所有开放的端口号输出。

分析:使用socket连接,如果连接成功,认为端口开放,如果连接失败,认为端口关闭(有可能端口开放但连接失败,这里简单认为端口不开放)

使用到的库:socket, threading

过程:

先定义一个函数,对给定的(ip, port)进行扫描,看其是否能连接成功。


def tcpPortScan(ip, port, openPort):
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 创建套接字
sock.settimeout(0.1)   # 设置延时时间
try:
 result = sock.connect_ex((ip, port))
 if result == 0:    # 如果连接成功,返回值为0
  openPort.append(port) # 如果端口开放,就把端口port赋给openPort
except:
 pass
sock.close()     # 关闭套接字

当需要扫描目标地址的多个端口时,循环使用上述函数的话,扫描速度会极其慢,因为考虑使用多线程。

再定义一个函数,实现多线程扫描。


def threadingPortScan(host, portList, openPorts = []):

hostIP = socket.gethostbyname(host) # 获取域名对应的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连接是否成功,如果连接成功,则端口开放,不成功则端口关闭
'''

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) # 创建套接字
sock.settimeout(0.1)   # 设置延时时间
try:
 result = sock.connect_ex((ip, port))
 if result == 0:
  openPort.append(port) # 如果端口开放,就把端口port赋给openPort
except:
 pass
sock.close()     # 关闭套接字

def threadingPortScan(host, portList, openPorts = []):

hostIP = socket.gethostbyname(host) # 获取域名对应的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做一个测试,测试结果如下:


>>>please input domain: www.qq.com
www.qq.com open ports: [80, 843]

总结:这个小程序仅适用于新手练习,不适合真正应用。该简易端口扫描器仅能扫描出一部分端口,有些端口可能因为防火墙拦截导致扫描失败。

来源:https://blog.csdn.net/sime_km/article/details/79747334

标签:python,多线程,端口扫描
0
投稿

猜你喜欢

  • asp中提示至少一个参数没有被指定值 解决方法

    2013-06-01 20:14:00
  • python 实现的发送邮件模板【普通邮件、带附件、带图片邮件】

    2023-10-07 00:52:22
  • php简单生成一组与多组随机字符串的方法

    2023-10-04 02:10:09
  • python实现会员管理系统

    2023-11-13 19:44:46
  • 在Linux下安装Oracle

    2010-07-30 12:46:00
  • 网站发布后Bootstrap框架引用woff字体无法正常显示的解决方法

    2023-08-13 00:26:58
  • 23条科学设计你网站的方法

    2008-03-23 14:12:00
  • python中的decimal类型转换实例详解

    2022-05-01 15:05:21
  • Laravel框架实现定时发布任务的方法

    2023-11-22 23:54:57
  • php利用cookies实现购物车的方法

    2023-07-23 08:32:37
  • 流动的线条 —— 中国汉字书法之美

    2009-10-30 18:15:00
  • 将pandas.dataframe的数据写入到文件中的方法

    2022-07-13 14:56:38
  • matplotlib之Font family [‘sans-serif‘] not found的问题解决

    2021-03-31 09:55:42
  • 数据库Oracle数据的异地的自动备份

    2010-07-27 13:28:00
  • Javascript程序优化

    2008-06-02 13:12:00
  • Python遍历文件夹和读写文件的实现代码

    2023-07-28 12:13:10
  • 基于微服务框架go-micro开发gRPC应用程序

    2023-06-22 21:19:27
  • 微信小程序实现日期格式化

    2023-07-20 20:28:32
  • python数据结构链表之单向链表(实例讲解)

    2021-01-17 12:51:19
  • mysql主从服务器配置特殊问题

    2011-01-04 19:56:00
  • asp之家 网络编程 m.aspxhome.com