这个扫描器用的是:
TCP全连接扫描!
TCP全连接,即完成一次完整的TCP连接!经过三次握手后来判断目标端口是否开放!
三次握手:
A 向 B发送一个带有SYN的TCP报文请求连接!
B 收到后向 A 发送一个带有ACK和SYN的TCP报文表示确认和请求连接!
A 收到后向 B发送一个带有ACK的TCP报文表示确认并正式开始连接!
给那些初学扫描器的小白们~~~
#-*- coding:utf-8 -*-
from socket import *
def portScanner(host,port):
try:
s = socket(AN_INET,SOCK_STREAM)
s.connect((host,port))
print('[+] %d open' % port)
s.close()
except:
print('[-] %d close' % port )
def main():
setdefaulttimeout(1)
for p in range(1,1024):
portScanner('127.0.0.1',p)
if __name__ == '__main__':
main()
拓展~
import optparse
from threading import *
from socket import *
setdefaulttimeout(5)
screenLock = Semaphore(value=1)
def connScan(tgtip,port):
ip_port = (tgtip,port)
sk = socket(AF_INET,SOCK_STREAM)
try:
sk.connect(ip_port)
sk.send("The is test!")
banner=sk.recv(100)
screenLock.acquire()
print "[+]Port %d Open"%(int(port))
print "[+]"+str(banner)
except Exception,sk_error:
screenLock.acquire()
#print sk_error
print "[-]Port %d Close"%(port)
finally:
screenLock.release()
sk.close()
def portScann(tgtHost,tgtPort):
try:
tgtip = gethostbyname(tgtHost)
print "[+]Scanner Host:"+str(tgtip)
for port in tgtPort:
print "[+]Scanner Port %d " %(int(port))
t = Thread(target=connScan,args=(tgtip,int(port)))
t.start()
except:
print "[-]Unknow The Host:"+str(tgtHost)
exit(0)
def main():
parser = optparse.OptionParser("Please Enter Option!")
parser.add_option("-H",dest="tgtHost",type="string",
help="Enter You Target!")
parser.add_option("-P",dest="tgtPort",type="string",
help="Enter Scanner Port!10,20!")
(options,args) = parser.parse_args()
if (options.tgtHost == None) | (options.tgtPort == None):
print parser.usage
exit(0)
tgtHost = options.tgtHost
tgtPort = options.tgtPort.split(',')
portScann(tgtHost,tgtPort)
if __name__ == '__main__':
main()