借助nmap写一个简单的python扫描 全连接

# coding=UTF-8
import optparse
import socket
import threading

screenLock = threading.Semaphore(value=1)
def connScan(tgtHost, tgtPort):
	try:
		connSkt = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
		connSkt.connect((tgtHost, tgtPort))
                connSkt.send('ViolentPython\r\n')
                results = connSkt.recv(100)
                screenLock.acquire()
		print('[+]%d/tcp open' % tgtPort)
                print('[+] ' + str(results))
	except:
                screenLock.acquire()
		print('[-]%d/tcp closed' % tgtPort)
        finally:
            screenLock.release()
            connSkt.close()

def portScan(tgtHost, tgtPorts):
	try:
		tgtIP = socket.gethostbyname(tgtHost)
	except:
		print("[-] Cannot resolve '%s': Unknown host" % tgtHost)
		return
	try:
		tgtName = socket.gethostbyaddr(tgtIP)
		print('\n[+] Scan Results for: ' + tgtName[0])
	except:
		print('\n[+] Scan Results for: ' + tgtIP)
	socket.setdefaulttimeout(1)
	for tgtPort in tgtPorts:
		print('Scanning port ' + str(tgtPort))
		t = threading.Thread(target=connScan, args=(tgtHost, int(tgtPort)))
		t.start()

def main():
    parser = optparse.OptionParser('usage %prog -H <target host> -p <target port>')
    parser.add_option('-H', dest='tgtHost', type='string', help='specify target host')
    parser.add_option('-p', dest='tgtPort', type='int', help='specify target port')
    (option, args)=parser.parse_args()
    tgtHost = option.tgtHost
    tgtPort = option.tgtPort
    args.append(tgtPort)
    if((tgtHost==None)|(tgtPort==None)):
        print('[-] You must specify a target host and port[s]!')
        exit(0)
    portScan(tgtHost, args)
    
if __name__ == '__main__':
    main()

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值