mirror of
				https://github.com/sqlmapproject/sqlmap.git
				synced 2025-10-26 13:41:10 +03:00 
			
		
		
		
	Bug fix to resume of --technique
This commit is contained in:
		
							parent
							
								
									eea96c5b8d
								
							
						
					
					
						commit
						e96a533a04
					
				|  | @ -168,18 +168,32 @@ def resumeConfKb(expression, url, value): | ||||||
|     if expression == "Injection data" and url == conf.url: |     if expression == "Injection data" and url == conf.url: | ||||||
|         injection = base64unpickle(value[:-1]) |         injection = base64unpickle(value[:-1]) | ||||||
| 
 | 
 | ||||||
|         infoMsg = "resuming injection data from session file" |  | ||||||
|         logger.info(infoMsg) |  | ||||||
| 
 |  | ||||||
|         if injection.place in conf.paramDict and \ |         if injection.place in conf.paramDict and \ | ||||||
|            injection.parameter in conf.paramDict[injection.place]: |            injection.parameter in conf.paramDict[injection.place]: | ||||||
| 
 | 
 | ||||||
|             if not conf.tech or intersect(conf.tech, injection.data.keys()): |             if not conf.tech or intersect(conf.tech, injection.data.keys()): | ||||||
|  |                 # Strip not required techniques (--technique switch) | ||||||
|                 if intersect(conf.tech, injection.data.keys()): |                 if intersect(conf.tech, injection.data.keys()): | ||||||
|                     injection.data = dict(filter(lambda (key, item): key in conf.tech, injection.data.items())) |                     injection.data = dict(filter(lambda (key, item): key in conf.tech, injection.data.items())) | ||||||
| 
 | 
 | ||||||
|                 if injection not in kb.injections: |                 infoMsg = "resuming injection data for technique%s " % ("s" if len(injection.data.keys()) > 1 else "") | ||||||
|  |                 infoMsg += "%s " % " & ".join([PAYLOAD.SQLINJECTION[k] for k in injection.data.keys()]) | ||||||
|  |                 infoMsg += "from session file" | ||||||
|  |                 logger.info(infoMsg) | ||||||
|  | 
 | ||||||
|  |                 if len(kb.injections) == 0: | ||||||
|                     kb.injections.append(injection) |                     kb.injections.append(injection) | ||||||
|  |                 else: | ||||||
|  |                     for resumedInj in kb.injections: | ||||||
|  |                         for inj, data in injection.data.items(): | ||||||
|  |                             if inj not in resumedInj.data: | ||||||
|  |                                 kb.injections[kb.injections.index(resumedInj)].data[inj] = data | ||||||
|  |             else: | ||||||
|  |                 warnMsg = "not resuming injection data for technique%s " % ("s" if len(injection.data.keys()) > 1 else "") | ||||||
|  |                 warnMsg += "%s " % " & ".join([PAYLOAD.SQLINJECTION[k] for k in injection.data.keys()]) | ||||||
|  |                 warnMsg += "from session file because you provided " | ||||||
|  |                 warnMsg += "different technique(s) to be tested on this run" | ||||||
|  |                 logger.warn(warnMsg) | ||||||
|         else: |         else: | ||||||
|             warnMsg = "there is an injection in %s parameter '%s' " % (injection.place, injection.parameter) |             warnMsg = "there is an injection in %s parameter '%s' " % (injection.place, injection.parameter) | ||||||
|             warnMsg += "but you did not provided it this time" |             warnMsg += "but you did not provided it this time" | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user