python编写的端口扫描脚本

 实训项目制作的端口扫描脚本

附有详细的使用命令解释

可以实现单个端口进行扫描和端进行扫描

eg:1-65535

import optparse  # 导入用于解析命令行参数的模块
import socket  # 导入用于网络通信的模块

# 定义函数:扫描指定主机的指定端口
def PortScan(targetHost, targetPort):
    try:
        connSkt = socket.socket(socket.AF_INET, socket.SOCK_STREAM)  # 创建套接字对象,   # socket.AF_INET 表示地址族(Address Family),用于指定套接字使用的地址类型,这里是 IPv4 地址族。
                                                                                        # socket.SOCK_STREAM 表示套接字类型(Socket Type),用于指定套接字的传输类型,这里是 TCP。
        connSkt.settimeout(1)  # 设置连接超时时间为 1 秒
        connSkt.connect((targetHost, targetPort))  # 尝试连接指定的主机和端口
        connSkt.send(b'PortScan\r\n')  # 发送字节数据到连接的套接字
        results = connSkt.recv(1000)  # 接收数据并存储结果
        print('[+] %d/tcp open' % targetPort)  # 输出端口开放信息
        print('[+] ' + str(results))  # 输出收到的数据
    except socket.error:
        print('[-] %d/tcp closed' % targetPort)  # 端口关闭或发生错误时输出信息
    finally:
        connSkt.close()  # 关闭套接字连接

# 定义函数:执行端口扫描
def Scan(targetHost, targetPorts):
    try:
        tgtIP = socket.getaddrinfo(targetHost, 0)[0][4][0]  # 获取目标主机的 IP 地址,socket.getaddrinfo(targetHost, 0) 返回一个包含解析信息的列表。
    except socket.gaierror:
        print('[-] Cannot resolve %s: Unknown host' % targetHost)  # 若无法解析主机名则输出错误信息并返回
        return
    try:
        tgtName = socket.gethostbyaddr(tgtIP)[0]    # 获取 IP 地址对应的主机名
                                                    # socket.gethostbyaddr() 函数用于执行 IP 地址到主机名的反向 DNS 解析。它接受一个 IP 地址作为参数,并返回与该地址关联的主机名。
        print("\n[+] Scan results for: " + tgtName)  # 输出扫描结果的主机名
    except socket.herror:                       # 表示与主机和网络相关的错误。
        print("Scan Results for: " + tgtIP)  # 若无法获取主机名则输出 IP 地址
    for targetPort in targetPorts:  # 遍历指定的端口列表
        print("Scanning port: " + str(targetPort))  # 输出当前正在扫描的端口
        PortScan(targetHost, int(targetPort))  # 调用 PortScan 函数扫描各个端口

# 解析端口范围参数
def parse_port_range(port_range):
    ports = []
    try:
        if "-" in port_range:
            start, end = port_range.split("-")      #split("-") 方法通过分隔符 "-" 将字符串 port_range 拆分成两部分,左侧部分是起始端口,右侧部分是结束端口。这两部分被赋值给 start 和 end 变量。
            for port in range(int(start), int(end) + 1):
                ports.append(port)
        else:
            ports.append(int(port_range))
    except ValueError:
        print("Invalid port range specified. Please use format 'start-end' or 'port'.")
        exit(0)
    return ports

# 主函数
def main():
    parser = optparse.OptionParser("Usage prog -H <target host> -p <target ports>")        # 是 Python 中用于解析命令行参数的模块。它允许您编写带有选项和参数的命令行接口,并解析用户提供的输入
    parser.add_option('-H', dest='targetHost', type='string', help='specify target host')   # add_option() 方法用于添加选项,
                                                                                            # dest 参数用于指定选项被解析后存储的目标属性名称。当用户在命令行中使用选项时,解析器会将解析后的值存储到指定的目标属性中。
                                                                                            # type 参数用于指定在解析命令行参数时所期望的数据类型。这个参数允许您告诉解析器应该将参数解析为何种数据类型。
                                                                                            # string 是一个数据类型或一个表示字符类型的字符串
    parser.add_option('-p', dest='targetPort', type='string', help='specify target port[s] inside \"\" separated by commas(1-65535)')
    (options, args) = parser.parse_args()               #parse_args() 方法用于解析命令行参数,并返回解析后的结果。
    targetHost = options.targetHost  # 获取目标主机
    port_range = options.targetPort  # 获取端口范围参数

    if (targetHost is None) or (port_range is None):  # 如果未提供目标主机或端口范围,则输出用法信息并退出程序
        print(parser.usage)                     # parser.usage 是一个属性,用于获取程序使用说明的自定义文本。
        exit(0)

    targetPorts = parse_port_range(port_range)  # 解析端口范围参数

    Scan(targetHost, targetPorts)  # 调用 Scan 函数执行端口扫描

# 程序入口
if __name__ == "__main__":
    main()  # 调用主函数开始执行端口扫描
 

  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 你好,我是 CSDN 开发的 C 知道,关于你的问题,我可以回答。以下是一个简单的 Python 端口扫描脚本示例: ```python import socket target_host = input("请输入要扫描的目标主机:") target_ports = input("请输入要扫描的目标端口(多个端口用逗号分隔):") # 将输入的端口号转换为列表 target_ports = target_ports.split(",") # 创建 socket 对象 client = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 设置超时时间 client.settimeout(.5) # 遍历端口列表,进行扫描 for port in target_ports: try: # 连接目标主机和端口 client.connect((target_host, int(port))) print("端口 {} 开放".format(port)) except: print("端口 {} 关闭".format(port)) finally: # 关闭连接 client.close() ``` 希望能够帮助到你。 ### 回答2: 端口扫描网络安全中的一项重要任务,可以用来探测目标主机上开放的网络端口,进而判断目标主机上的服务或应用程序。下面是一个使用Python编写的简单端口扫描脚本。 ```python import socket # 定义要扫描的目标主机和端口范围 target_host = "localhost" target_ports = [80, 443, 8080] # 创建socket对象 sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 设置超时时间(可选) sock.settimeout(2) # 遍历端口范围,进行扫描 for port in target_ports: try: # 尝试连接目标主机的指定端口 result = sock.connect_ex((target_host, port)) # 判断连接是否成功 if result == 0: print("Port {} is open".format(port)) else: print("Port {} is closed".format(port)) except socket.timeout: print("Port {} timed out".format(port)) except socket.error: print("Error connecting to port {}".format(port)) finally: # 关闭socket连接 sock.close() ``` 以上脚本使用了Python的`socket`模块,通过`socket.socket()`方法创建一个TCP socket对象,并设置超时时间。然后,通过遍历指定的端口范围,使用`sock.connect_ex()`方法来尝试连接目标主机的每个端口。连接成功则表示该端口为开放状态,否则表示该端口为关闭状态。异常处理部分用于处理超时或连接错误的情况。 该脚本可以通过修改`target_host`和`target_ports`的值来扫描不同的目标主机和端口范围。注意:在进行端口扫描时,请遵守法律和道德规范,确保已取得所有必要的授权。 ### 回答3: Python是一种功能强大的编程语言,可以用来编写端口扫描脚本。以下是一个简单的示例: ```python import socket # 定义要扫描的目标主机和端口范围 target_host = "127.0.0.1" start_port = 1 end_port = 100 # 循环扫描指定范围内的端口 for port in range(start_port, end_port+1): # 创建一个socket对象 client = socket.socket(socket.AF_INET, socket.SOCK_STREAM) client.settimeout(0.5) # 设置连接超时时间为0.5秒 try: # 尝试连接目标主机的指定端口 result = client.connect_ex((target_host, port)) if result == 0: print(f"端口 {port} 是开放的") except Exception as e: print(f"发生异常:{e}") finally: client.close() # 关闭socket连接 ``` 在上述代码中,我们首先导入了socket模块,然后定义了目标主机和要扫描的端口范围。接下来,我们通过一个循环迭代的方式,依次尝试连接每个端口。连接成功返回0,表示端口是开放的,然后我们打印出来。如果连接出现异常,则打印异常信息。最后,我们要记得关闭socket连接。 使用这个脚本,你可以指定要扫描的目标主机和端口范围,然后运行脚本,它将会依次扫描指定范围内的端口,并将开放的端口打印出来。请注意,扫描端口时可能需要一段时间,具体时间取决于目标主机和端口的数量。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值