mirror of
				https://github.com/sqlmapproject/sqlmap.git
				synced 2025-10-26 21:51:12 +03:00 
			
		
		
		
	Bug fix (payload escaping in XML payloads)
This commit is contained in:
		
							parent
							
								
									8d608dfdfe
								
							
						
					
					
						commit
						2bb5ba7fa2
					
				|  | @ -103,7 +103,7 @@ class ReqHandler(BaseHTTPRequestHandler): | ||||||
|             if self.data.startswith('{') and self.data.endswith('}'): |             if self.data.startswith('{') and self.data.endswith('}'): | ||||||
|                 params.update(json.loads(self.data)) |                 params.update(json.loads(self.data)) | ||||||
|             elif self.data.startswith('<') and self.data.endswith('>'): |             elif self.data.startswith('<') and self.data.endswith('>'): | ||||||
|                 params.update(dict(re.findall(r'name="([^"]+)" value="([^"]*)"', self.data))) |                 params.update(dict((_[0], _[1].replace("'", "'").replace(""", '"').replace("<", '<').replace(">", '>').replace("&", '&')) for _ in re.findall(r'name="([^"]+)" value="([^"]*)"', self.data))) | ||||||
|             else: |             else: | ||||||
|                 params.update(parse_qs(self.data)) |                 params.update(parse_qs(self.data)) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -18,7 +18,7 @@ from lib.core.enums import OS | ||||||
| from thirdparty.six import unichr as _unichr | from thirdparty.six import unichr as _unichr | ||||||
| 
 | 
 | ||||||
| # sqlmap version (<major>.<minor>.<month>.<monthly commit>) | # sqlmap version (<major>.<minor>.<month>.<monthly commit>) | ||||||
| VERSION = "1.3.11.46" | VERSION = "1.3.11.47" | ||||||
| TYPE = "dev" if VERSION.count('.') > 2 and VERSION.split('.')[-1] != '0' else "stable" | TYPE = "dev" if VERSION.count('.') > 2 and VERSION.split('.')[-1] != '0' else "stable" | ||||||
| TYPE_COLORS = {"dev": 33, "stable": 90, "pip": 34} | TYPE_COLORS = {"dev": 33, "stable": 90, "pip": 34} | ||||||
| VERSION_STRING = "sqlmap/%s#%s" % ('.'.join(VERSION.split('.')[:-1]) if VERSION.count('.') > 2 and VERSION.split('.')[-1] == '0' else VERSION, TYPE) | VERSION_STRING = "sqlmap/%s#%s" % ('.'.join(VERSION.split('.')[:-1]) if VERSION.count('.') > 2 and VERSION.split('.')[-1] == '0' else VERSION, TYPE) | ||||||
|  |  | ||||||
|  | @ -932,7 +932,7 @@ class Connect(object): | ||||||
|                 if kb.postHint in (POST_HINT.SOAP, POST_HINT.XML): |                 if kb.postHint in (POST_HINT.SOAP, POST_HINT.XML): | ||||||
|                     # payloads in SOAP/XML should have chars > and < replaced |                     # payloads in SOAP/XML should have chars > and < replaced | ||||||
|                     # with their HTML encoded counterparts |                     # with their HTML encoded counterparts | ||||||
|                     payload = payload.replace('>', ">").replace('<', "<") |                     payload = payload.replace('&', "&").replace('>', ">").replace('<', "<").replace('"', """).replace("'", "'")  # Reference: https://stackoverflow.com/a/1091953 | ||||||
|                 elif kb.postHint == POST_HINT.JSON: |                 elif kb.postHint == POST_HINT.JSON: | ||||||
|                     payload = escapeJsonValue(payload) |                     payload = escapeJsonValue(payload) | ||||||
|                 elif kb.postHint == POST_HINT.JSON_LIKE: |                 elif kb.postHint == POST_HINT.JSON_LIKE: | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user