mirror of
				https://github.com/sqlmapproject/sqlmap.git
				synced 2025-10-25 13:11:00 +03:00 
			
		
		
		
	Patch for an Issue #347
This commit is contained in:
		
							parent
							
								
									a38b3e397c
								
							
						
					
					
						commit
						f7eda07d92
					
				|  | @ -86,6 +86,7 @@ from lib.core.settings import DEFAULT_GET_POST_DELIMITER | |||
| from lib.core.settings import DEFAULT_MSSQL_SCHEMA | ||||
| from lib.core.settings import DEPRECATED_OPTIONS | ||||
| from lib.core.settings import DESCRIPTION | ||||
| from lib.core.settings import DOLLAR_MARKER | ||||
| from lib.core.settings import DUMMY_SQL_INJECTION_CHARS | ||||
| from lib.core.settings import DUMMY_USER_INJECTION | ||||
| from lib.core.settings import DYNAMICITY_MARK_LENGTH | ||||
|  | @ -2041,6 +2042,10 @@ def urlencode(value, safe="%&=", convall=False, limit=False): | |||
|         if all(map(lambda x: '%' in x, [safe, value])) and not kb.tamperFunctions: | ||||
|             value = re.sub("%(?![0-9a-fA-F]{2})", "%25", value) | ||||
| 
 | ||||
|         if '$' in value and '$' not in safe: | ||||
|             for match in re.finditer(r"\b([\w$]*\$[\w$]*)=", value): | ||||
|                 value = value.replace(match.group(1), match.group(1).replace('$', DOLLAR_MARKER)) | ||||
| 
 | ||||
|         while True: | ||||
|             result = urllib.quote(utf8encode(value), safe) | ||||
| 
 | ||||
|  | @ -2056,6 +2061,9 @@ def urlencode(value, safe="%&=", convall=False, limit=False): | |||
|             else: | ||||
|                 break | ||||
| 
 | ||||
|     if result: | ||||
|         result = result.replace(DOLLAR_MARKER, '$') | ||||
| 
 | ||||
|     return result | ||||
| 
 | ||||
| def runningAsAdmin(): | ||||
|  |  | |||
|  | @ -37,6 +37,7 @@ UPPER_RATIO_BOUND = 0.98 | |||
| PARAMETER_AMP_MARKER = "__AMP__" | ||||
| PARAMETER_SEMICOLON_MARKER = "__SEMICOLON__" | ||||
| PARTIAL_VALUE_MARKER = "__PARTIAL__" | ||||
| DOLLAR_MARKER = "__DOLLAR_MARK__" | ||||
| URI_QUESTION_MARKER = "__QUESTION_MARK__" | ||||
| ASTERISK_MARKER = "__ASTERISK_MARK__" | ||||
| 
 | ||||
|  |  | |||
|  | @ -620,8 +620,8 @@ class Connect(object): | |||
|                         payload = json.dumps(payload)[1:-1] | ||||
|                 value = agent.replacePayload(value, payload) | ||||
|             else: | ||||
|                 if not skipUrlEncode and place in (PLACE.GET, PLACE.COOKIE, PLACE.URI): | ||||
|                     # GET, URI and Cookie need to be throughly URL encoded (POST is encoded down below) | ||||
|                 if not skipUrlEncode and place in (PLACE.GET, PLACE.POST, PLACE.COOKIE, PLACE.URI): | ||||
|                     # GET, POST, URI and Cookie payload needs to be throughly URL encoded | ||||
|                     payload = urlencode(payload, '%', False, place != PLACE.URI) | ||||
|                     value = agent.replacePayload(value, payload) | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	Block a user