1

因此,我正在使用我迄今为止所学的内容制作一个 python 程序,其中用户输入两个 ips,代表要扫描的 ips 的开始和范围,而不是将所需的 ip 保存在文本文件中。这是我想出的:

   #ip range and scanning
import socket
import sys
ok=[]
def ipscan(start2,port):
    s=socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    s.settimeout(2)
    try:
        s.connect((start2,port))
        print start2 ,'-->port %s is Open'%port
        ok.append(start2)
    except: print start2 ,'-->port %s is Closed ! '%port
def iprange(start,end):
    while end>start:
       start[3]+=1
       ipscan('.'.join(map(str,start)),p)
       for i in (3,2,1,0):
          if start[i]==255:
             start[i-1]+=1
             start[i]=0
 #--------------------------------------------#    
sta=map(int,raw_input('From : ').split('.'))
fin=map(int,raw_input('to : ').split('.'))
p=input('Port to scan : ')
iprange(sta,fin)
print '-----------end--------------'
of=open('Output.txt','w')
for ip in ok:
    of.writelines(ip+'\n')
of.close()

它似乎正在工作,但我需要确定,并想知道我是否可以让它更快?或者是否有更好的方法。

4

1 回答 1

1

你可以使用nmap;)

您的套接字连接都是顺序的。您可以并行化连接,因为这是缓慢的因素,特别是对于过滤(无响应)端口。

于 2013-03-23T20:29:03.113 回答