240 发简信
IP属地:湖南
  • 这个扫描器用的是:
    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()