python制作一个简单的端口扫描器,用于检测目标主机上指定端口的开放状态

ops/2024/11/14 2:24:02/

import argparse  # 用于解析命令行参数
from socket import *  # 导入 socket 库的所有内容,用于网络通信
from threading import *  # 导入 threading 库的所有内容,用于多线程操作

# 创建一个信号量,初始值为 1,用于线程同步,防止多个线程同时打印导致输出混乱
screenLock = Semaphore(value=1)

# 定义 connScan 函数,用于扫描单个端口
def connScan(tgtHost, tgtport):
    try:
        # 创建一个 socket 对象,AF_INET 表示使用 IPv4,SOCK_STREAM 表示使用 TCP
        connSkt = socket(AF_INET, SOCK_STREAM)
        # 尝试连接到目标主机的指定端口
        connSkt.connect((tgtHost, tgtport))
        # 发送一个字符串,表示连接成功
        connSkt.send('ViolentPython\r\n'.encode())  
        # 接收返回的数据,最多接收 100 字节
        results = connSkt.recv(100)
        # 获取屏幕锁,确保打印输出时不会与其他线程冲突
        screenLock.acquire()
        # 打印端口开放的信息
        print(f'[+]{tgtport}/tcp open')
        # 打印接收到的数据
        print(f'[+]{results.decode("utf-8")}')  
    except:
        # 如果发生异常,获取屏幕锁并打印端口关闭的信息
        screenLock.acquire()
        print(f'[-]{tgtport}/tcp closed')
    finally:
        # 释放屏幕锁
        screenLock.release()
        # 关闭 socket 连接
        connSkt.close()

# 定义 portScan 函数,用于扫描多个端口
def portScan(tgtHost, tgtPorts):
    try:
        # 将目标主机名解析为 IP 地址
        tgtIP = gethostbyname(tgtHost)
    except:
        # 如果解析失败,打印错误信息并返回
        print(f"[-] Cannot resolve '{tgtHost}':Unknown host")
        return
    try:
        # 将 IP 地址解析为主机名
        tgtName = gethostbyaddr(tgtIP)
        # 打印扫描结果的标题
        print(f'\n[+]Scan Results for:{tgtName[0]}')
    except:
        # 如果解析失败,打印扫描结果的标题(使用 IP 地址)
        print(f'\n[+]Scan Results for:{tgtIP}')
    # 设置 socket 的默认超时时间为 1 秒
    setdefaulttimeout(1)
    # 遍历所有要扫描的端口
    for tgtPort in tgtPorts:
        # 为每个端口创建一个新的线程,调用 connScan 函数进行扫描
        t = Thread(target=connScan, args=(tgtHost, int(tgtPort)))
        t.start()

# 定义 main 函数,用于解析命令行参数并启动扫描
def main():
    # 创建一个命令行参数解析器
    parser = argparse.ArgumentParser(description='Port scanner usage')
    # 添加 -H 参数,用于指定目标主机
    parser.add_argument('-H', dest='tgtHost', type=str, help='specify target host')
    # 添加 -p 参数,用于指定要扫描的端口,端口之间用逗号分隔
    parser.add_argument('-p', dest='tgtPort', type=str, help='specify target port[s] separated by comma')
    # 解析命令行参数
    options = parser.parse_args()
    # 获取目标主机和端口
    tgtHost = options.tgtHost
    tgtPorts = options.tgtPort
    # 检查是否指定了目标主机和端口
    if tgtHost is None:
        print("请正确指定目标主机,使用 -H 参数输入目标主机信息。")
        exit(0)
    if tgtPorts is None:
        print("请正确指定目标端口,使用 -p 参数输入目标端口信息(多个端口用逗号隔开)。")
        exit(0)
    # 将端口字符串分割为列表
    tgtPorts = tgtPorts.split(',')
    # 调用 portScan 函数开始扫描
    portScan(tgtHost, tgtPorts)

# 如果直接运行这个脚本,则调用 main 函数
if __name__ == "__main__":
    main()

输出结果


http://www.ppmy.cn/ops/133440.html

相关文章

NumPy与TensorFlow-tf.tensor异同点

NumPy数组与TenosrFlow中的张量(即tf.tensor)有很多相似地方,而且可以互相转换。下表总结了NumPy与tf.tensor的异同点。 NumPy与tf.tensor的异同点 操作类别NumPyTensorFlow 2数据类型np.ndarraytf.Tensornp.float32tf.float32np.float64tf…

制造企业数字化中台(技术中台、数据中台、业务中台)建设方案

文件是一份关于制造企业数字化中台建设方案的详细报告,由郎丰利1519整理制作。报告内容涵盖了数字化中台的总体解决方案、技术中台(A)、数据中台(B)和业务中台(C)的架构和功能。以下是对PPT内容…

九州未来再度入选2024边缘计算TOP100

随着数智化转型的浪潮不断高涨,边缘计算作为推动各行业智能化升级的重要基石,正在成为支持万物智能化的关键点。近日,德本咨询(DBC)联合《互联网周刊》(CIW)与中国社会科学院信息化研究中心(CIS),共同发布《2024边缘计算TOP100》榜…

算法——移除元素(leetcode27)

对于移除元素这道题来讲,我首先想到的还是双指针,根据题目要求我们需要在给定的一组数组中找出与目标值不同的元素数量并且将与目标值不同的元素全部移至数组左边右边则不需关注数组元素的大小,我们利用两个指针一个指向数组首部位置(左指针&…

多线程之Semaphore信号量

一、什么是信号量 Semaphore(信号量)是用来控制同时访问特定资源的线程数量,它通过协调各个线程,以保证合理的使用公共资源。在多线程中经常会遇到该应用场景,信号量如同交通公路中的红绿灯一样,需要限流&…

ThinkBook 14+ 2024 Ubuntu 触控板失效 驱动缺失问题解决

首先我的电脑是thinkbook14 2024,从ubuntu18到ubuntu24,笔者整个都试了一遍,触摸板都没反应,确认不是linux系统内核问题,原因为驱动缺失。 解决步骤: (1)下载驱动,网址如…

微搭低代码入门01变量

目录 1 变量的定义2 变量的赋值3 变量的类型4 算术运算符5 字符串的连接6 模板字符串7 检查变量的类型8 解构赋值8.1 数组的解构赋值8.2 对象的解构赋值 9 类型转换9.1 转换为字符串9.2 转换为数字9.3 转换为布尔值 总结 好些零基础的同学,在使用低代码的时候&#…

React Hooks在现代前端开发中的应用

💓 博客主页:瑕疵的CSDN主页 📝 Gitee主页:瑕疵的gitee主页 ⏩ 文章专栏:《热点资讯》 React Hooks在现代前端开发中的应用 React Hooks在现代前端开发中的应用 React Hooks在现代前端开发中的应用 引言 React Hooks …