mirror of
https://github.com/sqlmapproject/sqlmap.git
synced 2024-11-29 13:03:50 +03:00
Patch for an Issue #304
This commit is contained in:
parent
45d6fdcdc8
commit
2b64c10710
|
@ -231,7 +231,7 @@ def decodePage(page, contentEncoding, contentType):
|
||||||
kb.pageEncoding = conf.charset
|
kb.pageEncoding = conf.charset
|
||||||
|
|
||||||
# can't do for all responses because we need to support binary files too
|
# can't do for all responses because we need to support binary files too
|
||||||
if contentType and not isinstance(page, unicode) and any(map(lambda x: x in contentType.lower(), ("text/txt", "text/raw", "text/html", "text/xml"))):
|
if contentType and not isinstance(page, unicode) and any(map(lambda _: _ in contentType.lower(), ("text/txt", "text/raw", "text/html", "text/xml"))):
|
||||||
# e.g. Ãëàâà
|
# e.g. Ãëàâà
|
||||||
if "&#" in page:
|
if "&#" in page:
|
||||||
page = re.sub('&#(\d{1,3});', lambda _: chr(int(_.group(1))) if int(_.group(1)) < 256 else _.group(0), page)
|
page = re.sub('&#(\d{1,3});', lambda _: chr(int(_.group(1))) if int(_.group(1)) < 256 else _.group(0), page)
|
||||||
|
|
|
@ -71,7 +71,7 @@ def _comparison(page, headers, code, getRatioValue, pageLength):
|
||||||
return re.search(conf.regexp, rawResponse, re.I | re.M) is not None
|
return re.search(conf.regexp, rawResponse, re.I | re.M) is not None
|
||||||
|
|
||||||
# HTTP code to match when the query is valid
|
# HTTP code to match when the query is valid
|
||||||
if isinstance(code, int) and conf.code:
|
if conf.code:
|
||||||
return conf.code == code
|
return conf.code == code
|
||||||
|
|
||||||
if page:
|
if page:
|
||||||
|
|
|
@ -142,7 +142,11 @@ class Connect(object):
|
||||||
headers = conn.info()
|
headers = conn.info()
|
||||||
if headers and (headers.getheader(HTTPHEADER.CONTENT_ENCODING, "").lower() in ("gzip", "deflate")\
|
if headers and (headers.getheader(HTTPHEADER.CONTENT_ENCODING, "").lower() in ("gzip", "deflate")\
|
||||||
or "text" not in headers.getheader(HTTPHEADER.CONTENT_TYPE, "").lower()):
|
or "text" not in headers.getheader(HTTPHEADER.CONTENT_TYPE, "").lower()):
|
||||||
retVal = conn.read()
|
retVal = conn.read(MAX_CONNECTION_TOTAL_SIZE)
|
||||||
|
if len(retVal) == MAX_CONNECTION_TOTAL_SIZE:
|
||||||
|
warnMsg = "large compressed response detected. Disabling compression"
|
||||||
|
singleTimeWarnMessage(warnMsg)
|
||||||
|
kb.pageCompress = False
|
||||||
else:
|
else:
|
||||||
while True:
|
while True:
|
||||||
_ = conn.read(MAX_CONNECTION_CHUNK_SIZE)
|
_ = conn.read(MAX_CONNECTION_CHUNK_SIZE)
|
||||||
|
@ -794,7 +798,15 @@ class Connect(object):
|
||||||
pageLength = int(headers[HTTPHEADER.CONTENT_RANGE][headers[HTTPHEADER.CONTENT_RANGE].find('/') + 1:])
|
pageLength = int(headers[HTTPHEADER.CONTENT_RANGE][headers[HTTPHEADER.CONTENT_RANGE].find('/') + 1:])
|
||||||
|
|
||||||
if not pageLength:
|
if not pageLength:
|
||||||
page, headers, code = Connect.getPage(url=uri, get=get, post=post, cookie=cookie, ua=ua, referer=referer, host=host, silent=silent, method=method, auxHeaders=auxHeaders, response=response, raise404=raise404, ignoreTimeout=timeBasedCompare)
|
try:
|
||||||
|
page, headers, code = Connect.getPage(url=uri, get=get, post=post, cookie=cookie, ua=ua, referer=referer, host=host, silent=silent, method=method, auxHeaders=auxHeaders, response=response, raise404=raise404, ignoreTimeout=timeBasedCompare)
|
||||||
|
except MemoryError:
|
||||||
|
page, headers, code = None, None, None
|
||||||
|
warnMsg = "site returned insanely large response"
|
||||||
|
if kb.testMode:
|
||||||
|
warnMsg += " in testing phase. This is a common "
|
||||||
|
warnMsg += "behavior in custom WAF/IDS/IPS solutions"
|
||||||
|
singleTimeWarnMessage(warnMsg)
|
||||||
|
|
||||||
if conf.secondOrder:
|
if conf.secondOrder:
|
||||||
page, headers, code = Connect.getPage(url=conf.secondOrder, cookie=cookie, ua=ua, silent=silent, auxHeaders=auxHeaders, response=response, raise404=False, ignoreTimeout=timeBasedCompare, refreshing=True)
|
page, headers, code = Connect.getPage(url=conf.secondOrder, cookie=cookie, ua=ua, silent=silent, auxHeaders=auxHeaders, response=response, raise404=False, ignoreTimeout=timeBasedCompare, refreshing=True)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user