BitTigerio 2017-12-15
import optparse
import socket
from socket import *<br /><br />'''<br />python 2.7.12<br />通过TCP连接来判断指定IP是否开放了指定端口<br />'''<br />def connScan(tgtHost,tgtPort):
try:
connSkt = socket(AF_INET, SOCK_STREAM)
connSkt.connect((tgtHost,tgtPort))
connSkt.send('ViolentPython\r\n')
results = connSkt.recv(100)
print '[+] %d/tcp open' % tgtPort
print '[+] ' + str(results) + '\n'
connSkt.close()
except:
print '[-] %d/tcp closed' % tgtPort + '\n'
def portScan(tgtHost,tgtPorts):
try:
tgtIP = gethostbyname(tgtHost)
except:
print "[-] Cannot resolve '%s': Unknown host" %tgtHost + '\n'
return
try:
tgtName = gethostbyaddr(tgtIP)
print '\n[+] Scan Results for: ' + tgtName[0]
except:
print '\n[+] Scan Results for: ' + tgtIP + '\n'
setdefaulttimeout(1)
for tgtPort in tgtPorts:
print '[*] Scanning port ' + tgtPort
connScan(tgtHost,int(tgtPort))
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='string',help='specify target port[s] separated by comma')
(options, args) = parser.parse_args()
tgtHost = options.tgtHost
tgtPorts = str(options.tgtPort).split(',')
if (tgtHost == None) | (tgtPorts[0] == None):
print '[-] You must specify a target host and port[s].'
exit(0)
portScan(tgtHost,tgtPorts)
if __name__ == '__main__':
main()