mirror of
				https://github.com/sqlmapproject/sqlmap.git
				synced 2025-10-26 13:41:10 +03:00 
			
		
		
		
	adding support for meta HTML header 'refresh' - popular one amongst login pages (stumbled when tested blind injections on Mutillidae login page)
This commit is contained in:
		
							parent
							
								
									7cf4ba83dc
								
							
						
					
					
						commit
						d28ca5809b
					
				|  | @ -221,6 +221,9 @@ ERROR_PARSING_REGEXES = ( | ||||||
| # Regular expression used for parsing charset info from meta html headers | # Regular expression used for parsing charset info from meta html headers | ||||||
| META_CHARSET_REGEX  = r'<meta http-equiv="?content-type"?[^>]+charset=(?P<result>[^">]+)' | META_CHARSET_REGEX  = r'<meta http-equiv="?content-type"?[^>]+charset=(?P<result>[^">]+)' | ||||||
| 
 | 
 | ||||||
|  | # Regular expression used for parsing refresh info from meta html headers | ||||||
|  | META_REFRESH_REGEX  = r'<meta http-equiv="?refresh"?[^>]+content="?[^">]+url=(?P<result>[^">]+)' | ||||||
|  | 
 | ||||||
| # Regular expression used for parsing empty fields in tested form data | # Regular expression used for parsing empty fields in tested form data | ||||||
| EMPTY_FORM_FIELDS_REGEX = r'(?P<result>[^=]+=(&|\Z))' | EMPTY_FORM_FIELDS_REGEX = r'(?P<result>[^=]+=(&|\Z))' | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -21,6 +21,7 @@ from lib.core.common import average | ||||||
| from lib.core.common import calculateDeltaSeconds | from lib.core.common import calculateDeltaSeconds | ||||||
| from lib.core.common import clearConsoleLine | from lib.core.common import clearConsoleLine | ||||||
| from lib.core.common import cpuThrottle | from lib.core.common import cpuThrottle | ||||||
|  | from lib.core.common import extractRegexResult | ||||||
| from lib.core.common import getCurrentThreadData | from lib.core.common import getCurrentThreadData | ||||||
| from lib.core.common import getFilteredPageContent | from lib.core.common import getFilteredPageContent | ||||||
| from lib.core.common import unicodeToSafeHTMLValue | from lib.core.common import unicodeToSafeHTMLValue | ||||||
|  | @ -43,6 +44,7 @@ from lib.core.enums import PLACE | ||||||
| from lib.core.exception import sqlmapConnectionException | from lib.core.exception import sqlmapConnectionException | ||||||
| from lib.core.exception import sqlmapSyntaxException | from lib.core.exception import sqlmapSyntaxException | ||||||
| from lib.core.settings import HTTP_SILENT_TIMEOUT | from lib.core.settings import HTTP_SILENT_TIMEOUT | ||||||
|  | from lib.core.settings import META_REFRESH_REGEX | ||||||
| from lib.core.settings import MIN_TIME_RESPONSES | from lib.core.settings import MIN_TIME_RESPONSES | ||||||
| from lib.core.settings import URI_HTTP_HEADER | from lib.core.settings import URI_HTTP_HEADER | ||||||
| from lib.core.threads import getCurrentThreadData | from lib.core.threads import getCurrentThreadData | ||||||
|  | @ -96,6 +98,7 @@ class Connect: | ||||||
|         auxHeaders      = kwargs.get('auxHeaders',    None) |         auxHeaders      = kwargs.get('auxHeaders',    None) | ||||||
|         response        = kwargs.get('response',      False) |         response        = kwargs.get('response',      False) | ||||||
|         ignoreTimeout   = kwargs.get('ignoreTimeout', False) |         ignoreTimeout   = kwargs.get('ignoreTimeout', False) | ||||||
|  |         refreshing      = kwargs.get('refreshing',    False) | ||||||
| 
 | 
 | ||||||
|         page            = "" |         page            = "" | ||||||
|         cookieStr       = "" |         cookieStr       = "" | ||||||
|  | @ -131,6 +134,13 @@ class Connect: | ||||||
| 
 | 
 | ||||||
|                 return page |                 return page | ||||||
| 
 | 
 | ||||||
|  |             elif refreshing: | ||||||
|  |                 # Reference(s):  | ||||||
|  |                 # http://vancouver-webpages.com/META/metatags.detail.html | ||||||
|  |                 # http://webdesign.about.com/od/metataglibraries/a/aa080300a.htm | ||||||
|  |                 get = None | ||||||
|  |                 post = None | ||||||
|  | 
 | ||||||
|             else: |             else: | ||||||
|                 if conf.parameters.has_key(PLACE.GET) and not get: |                 if conf.parameters.has_key(PLACE.GET) and not get: | ||||||
|                     get = conf.parameters[PLACE.GET] |                     get = conf.parameters[PLACE.GET] | ||||||
|  | @ -253,6 +263,24 @@ class Connect: | ||||||
|             page = decodePage(page, responseHeaders.get(HTTPHEADER.CONTENT_ENCODING), responseHeaders.get(HTTPHEADER.CONTENT_TYPE)) |             page = decodePage(page, responseHeaders.get(HTTPHEADER.CONTENT_ENCODING), responseHeaders.get(HTTPHEADER.CONTENT_TYPE)) | ||||||
|             status = getUnicode(conn.msg) |             status = getUnicode(conn.msg) | ||||||
| 
 | 
 | ||||||
|  |             if extractRegexResult(META_REFRESH_REGEX, page, re.DOTALL | re.IGNORECASE) and not refreshing: | ||||||
|  |                 url = extractRegexResult(META_REFRESH_REGEX, page, re.DOTALL | re.IGNORECASE) | ||||||
|  | 
 | ||||||
|  |                 if url.lower().startswith('http://'): | ||||||
|  |                     kwargs['url'] = url | ||||||
|  |                 else: | ||||||
|  |                     kwargs['url'] = conf.url[:conf.url.rfind('/')+1] + url | ||||||
|  | 
 | ||||||
|  |                 kwargs['refreshing'] = True | ||||||
|  | 
 | ||||||
|  |                 debugMsg = "got HTML meta refresh header" | ||||||
|  |                 logger.debug(debugMsg) | ||||||
|  | 
 | ||||||
|  |                 try: | ||||||
|  |                     return Connect.__getPageProxy(**kwargs) | ||||||
|  |                 except sqlmapSyntaxException: | ||||||
|  |                     pass | ||||||
|  | 
 | ||||||
|             # Explicit closing of connection object |             # Explicit closing of connection object | ||||||
|             if not conf.keepAlive: |             if not conf.keepAlive: | ||||||
|                 try: |                 try: | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user