python 使用socket模块扫描端口

python 使用socket模块扫描端口


import socket,sys

ip = sys.argv[1]    #接收参数
ports = sys.argv[2] #接收参数

def port_scan(ip,port):
    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    try:
        s.connect((ip, port))
        return True
    except:
        return False
    finally:
        s.close()

#执行test1.py 127.0.0.1 80,139,445
def get_ip(ip):
    for port in ports:
        if port_scan(ip,int(port)):
            print('[+]' + ip + ':'+ str(port) + ' Open')
        else:
            print('[-]' + ip + ':' + str(port) + ' Close'

#执行python.exe test1.py 127.0.0.1 440-445
def get_ip_port(ip,start_port,end_port):
    for port in range(int(start_port),int(end_port)+1):
        if port_scan(ip,port):
            print('[+]' + ip + ':'+ str(port) + ' Open')
        else:
            print('[-]' + ip + ':' + str(port) + ' Close')

if '-' in ports:
    ports = ports.split('-')
    get_ip_port(ip,ports[0],ports[1])
else:
    ports = ports.split(',')
    get_ip(ip)

执行结果

C:\Python385>python.exe test1.py 127.0.0.1 440-445
[-]127.0.0.1:440 Close
[-]127.0.0.1:441 Close
[-]127.0.0.1:442 Close
[-]127.0.0.1:443 Close
[-]127.0.0.1:444 Close
[+]127.0.0.1:445 Open

C:\Python385>python.exe test1.py 127.0.0.1 80,139,445
[-]127.0.0.1:80 Close
[-]127.0.0.1:139 Close
[+]127.0.0.1:445 Open

加入多线程模块实现

import socket,sys
from threading import Thread

def port_scan(ip,port):
    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    try:
        s.connect((ip, port))
        return True
    except:
        return False
    finally:
        s.close()

#执行test1.py 127.0.0.1 80,139,445
def get_ip(ip,port):
    if port_scan(ip,int(port)):
        print('[+]' + ip + ':'+ str(port) + ' Open')
    else:
        print('[-]' + ip + ':' + str(port) + ' Close')

#执行python.exe test1.py 127.0.0.1 440-445
def get_ip_port(ip,port):
        if port_scan(ip,port):
            print('[+]' + ip + ':'+ str(port) + ' Open')
        else:
            print('[-]' + ip + ':' + str(port) + ' Close')

def main(ports):
    if '-' in ports:
        ports = ports.split('-')
        for port in range(int(ports[0]), int(ports[1]) + 1):
            t = Thread(target=get_ip_port,args=(ip,port))
            t.start()
    else:
        ports = ports.split(',')
        for port in ports:
            t = Thread(target=get_ip,args=(ip,port))
            t.start()

if __name__ == "__main__":
    if len(sys.argv) == 3:
        ip = sys.argv[1]  # 接收参数
        ports = sys.argv[2]  # 接收参数
        main(ports)
    else:
        print(
            '''
            Error!
            Syntax: portscan.py [ip] [port]
            Example: portscan.py 127.0.0.1 135,139,445,3389 | portscan.py 127.0.0.1 1-1000
            '''
        )
        sys.exit()

执行结果

C:\Python385>python.exe test1.py 127.0.0.1

            Error!
            Syntax: portscan.py [ip] [port]
            Example: portscan.py 127.0.0.1 135,139,445,3389 | portscan.py 127.0.0.1 1-1000


C:\Python385>python.exe test1.py 127.0.0.1 440-445
[+]127.0.0.1:445 Open
[-]127.0.0.1:442 Close
[-]127.0.0.1:440 Close
[-]127.0.0.1:441 Close
[-]127.0.0.1:444 Close
[-]127.0.0.1:443 Close

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值