Implementation for an Issue #1540

This commit is contained in:
Miroslav Stampar 2015-11-16 23:46:10 +01:00
parent 4335ae8330
commit 41b8dfab86
2 changed files with 41 additions and 2 deletions

View File

@ -122,6 +122,7 @@ from lib.core.settings import NULL
from lib.core.settings import PARAMETER_SPLITTING_REGEX from lib.core.settings import PARAMETER_SPLITTING_REGEX
from lib.core.settings import PROBLEMATIC_CUSTOM_INJECTION_PATTERNS from lib.core.settings import PROBLEMATIC_CUSTOM_INJECTION_PATTERNS
from lib.core.settings import SITE from lib.core.settings import SITE
from lib.core.settings import SOCKET_PRE_CONNECT_QUEUE_SIZE
from lib.core.settings import SQLMAP_ENVIRONMENT_PREFIX from lib.core.settings import SQLMAP_ENVIRONMENT_PREFIX
from lib.core.settings import SUPPORTED_DBMS from lib.core.settings import SUPPORTED_DBMS
from lib.core.settings import SUPPORTED_OS from lib.core.settings import SUPPORTED_OS
@ -1014,10 +1015,44 @@ def _setDNSCache():
kb.cache[args] = socket._getaddrinfo(*args, **kwargs) kb.cache[args] = socket._getaddrinfo(*args, **kwargs)
return kb.cache[args] return kb.cache[args]
if not hasattr(socket, '_getaddrinfo'): if not hasattr(socket, "_getaddrinfo"):
socket._getaddrinfo = socket.getaddrinfo socket._getaddrinfo = socket.getaddrinfo
socket.getaddrinfo = _getaddrinfo socket.getaddrinfo = _getaddrinfo
def _setSocketPreConnect():
"""
Makes a pre-connect version of socket.connect
"""
def _():
while kb.threadContinue:
for address in socket._ready:
if len(socket._ready[address]) < SOCKET_PRE_CONNECT_QUEUE_SIZE:
s = socket.socket()
s._connect(address)
socket._ready[address].append(s._sock)
time.sleep(0.001)
def connect(self, address):
found = False
with kb.locks.socket:
if address not in socket._ready:
socket._ready[address] = []
if len(socket._ready[address]) > 0:
self._sock = socket._ready[address].pop(0)
found = True
if not found:
self._connect(address)
if not hasattr(socket, "_connect"):
socket._ready = {}
socket.socket._connect = socket.socket.connect
socket.socket.connect = connect
thread = threading.Thread(target=_)
thread.daemon = True
thread.start()
def _setHTTPHandlers(): def _setHTTPHandlers():
""" """
Check and set the HTTP/SOCKS proxy for all HTTP requests. Check and set the HTTP/SOCKS proxy for all HTTP requests.
@ -1803,7 +1838,7 @@ def _setKnowledgeBaseAttributes(flushAll=True):
kb.lastParserStatus = None kb.lastParserStatus = None
kb.locks = AttribDict() kb.locks = AttribDict()
for _ in ("cache", "count", "index", "io", "limit", "log", "redirect", "request", "value"): for _ in ("cache", "count", "index", "io", "limit", "log", "socket", "redirect", "request", "value"):
kb.locks[_] = threading.Lock() kb.locks[_] = threading.Lock()
kb.matchRatio = None kb.matchRatio = None
@ -2517,6 +2552,7 @@ def init():
_setHTTPAuthentication() _setHTTPAuthentication()
_setHTTPHandlers() _setHTTPHandlers()
_setDNSCache() _setDNSCache()
_setSocketPreConnect()
_setSafeVisit() _setSafeVisit()
_doSearch() _doSearch()
_setBulkMultipleTargets() _setBulkMultipleTargets()

View File

@ -466,6 +466,9 @@ ROTATING_CHARS = ('\\', '|', '|', '/', '-')
# Approximate chunk length (in bytes) used by BigArray objects (only last chunk and cached one are held in memory) # Approximate chunk length (in bytes) used by BigArray objects (only last chunk and cached one are held in memory)
BIGARRAY_CHUNK_SIZE = 1024 * 1024 BIGARRAY_CHUNK_SIZE = 1024 * 1024
# Maximum number of socket pre-connects
SOCKET_PRE_CONNECT_QUEUE_SIZE = 3
# Only console display last n table rows # Only console display last n table rows
TRIM_STDOUT_DUMP_SIZE = 256 TRIM_STDOUT_DUMP_SIZE = 256