mirror of
				https://github.com/sqlmapproject/sqlmap.git
				synced 2025-10-25 21:21:03 +03:00 
			
		
		
		
	Implementation of crawling results normalization
This commit is contained in:
		
							parent
							
								
									273004396c
								
							
						
					
					
						commit
						a660828cec
					
				|  | @ -1953,6 +1953,7 @@ def _setKnowledgeBaseAttributes(flushAll=True): | ||||||
|     kb.mergeCookies = None |     kb.mergeCookies = None | ||||||
|     kb.multipleCtrlC = False |     kb.multipleCtrlC = False | ||||||
|     kb.negativeLogic = False |     kb.negativeLogic = False | ||||||
|  |     kb.normalizeCrawlingChoice = None | ||||||
|     kb.nullConnection = None |     kb.nullConnection = None | ||||||
|     kb.oldMsf = None |     kb.oldMsf = None | ||||||
|     kb.orderByColumns = None |     kb.orderByColumns = None | ||||||
|  |  | ||||||
|  | @ -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.10.38" | VERSION = "1.3.10.39" | ||||||
| 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) | ||||||
|  |  | ||||||
|  | @ -195,6 +195,26 @@ def crawl(target): | ||||||
|             for url in threadData.shared.value: |             for url in threadData.shared.value: | ||||||
|                 kb.targets.add((urldecode(url, kb.pageEncoding), None, None, None, None)) |                 kb.targets.add((urldecode(url, kb.pageEncoding), None, None, None, None)) | ||||||
| 
 | 
 | ||||||
|  |         if kb.normalizeCrawlingChoice is None: | ||||||
|  |             message = "do you want to normalize " | ||||||
|  |             message += "crawling results [Y/n] " | ||||||
|  | 
 | ||||||
|  |             kb.normalizeCrawlingChoice = readInput(message, default='Y', boolean=True) | ||||||
|  | 
 | ||||||
|  |         if kb.normalizeCrawlingChoice: | ||||||
|  |             seen = set() | ||||||
|  |             results = OrderedSet() | ||||||
|  | 
 | ||||||
|  |             for target in kb.targets: | ||||||
|  |                 match = re.search(r"/[^/?]*\?.*\Z", target[0]) | ||||||
|  |                 if match: | ||||||
|  |                     key = re.sub(r"=[^=&]*", "=", match.group(0)) | ||||||
|  |                     if key not in seen: | ||||||
|  |                         results.add(target) | ||||||
|  |                         seen.add(key) | ||||||
|  | 
 | ||||||
|  |             kb.targets = results | ||||||
|  | 
 | ||||||
|         storeResultsToFile(kb.targets) |         storeResultsToFile(kb.targets) | ||||||
| 
 | 
 | ||||||
| def storeResultsToFile(results): | def storeResultsToFile(results): | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user