mirror of
				https://github.com/sqlmapproject/sqlmap.git
				synced 2025-10-25 21:21:03 +03:00 
			
		
		
		
	Minor bug fix for --search -C so that now if not columns are found (with criteria specified, e.g. -D testdb -T testtable), it won't ask to dump for the entries
This commit is contained in:
		
							parent
							
								
									e678219a8c
								
							
						
					
					
						commit
						7330dff255
					
				|  | @ -1093,7 +1093,7 @@ class Enumeration: | ||||||
|                     condQuery = " AND (%s)" % " OR ".join(condQueryStr % (condition, unsafeSQLIdentificatorNaming(col)) for col in sorted(colList)) |                     condQuery = " AND (%s)" % " OR ".join(condQueryStr % (condition, unsafeSQLIdentificatorNaming(col)) for col in sorted(colList)) | ||||||
| 
 | 
 | ||||||
|                     if colConsider == "1": |                     if colConsider == "1": | ||||||
|                         infoMsg += "LIKE '%s' " % ", ".join(unsafeSQLIdentificatorNaming(col) for col in sorted(colList)) |                         infoMsg += "like '%s' " % ", ".join(unsafeSQLIdentificatorNaming(col) for col in sorted(colList)) | ||||||
|                     else: |                     else: | ||||||
|                         infoMsg += "'%s' " % ", ".join(unsafeSQLIdentificatorNaming(col) for col in sorted(colList)) |                         infoMsg += "'%s' " % ", ".join(unsafeSQLIdentificatorNaming(col) for col in sorted(colList)) | ||||||
|                 else: |                 else: | ||||||
|  | @ -1162,7 +1162,7 @@ class Enumeration: | ||||||
|                     condQuery = " AND (%s)" % " OR ".join(condQueryStr % (condition, unsafeSQLIdentificatorNaming(col)) for col in sorted(colList)) |                     condQuery = " AND (%s)" % " OR ".join(condQueryStr % (condition, unsafeSQLIdentificatorNaming(col)) for col in sorted(colList)) | ||||||
| 
 | 
 | ||||||
|                     if colConsider == "1": |                     if colConsider == "1": | ||||||
|                         infoMsg += "LIKE '%s' " % ", ".join(unsafeSQLIdentificatorNaming(col) for col in sorted(colList)) |                         infoMsg += "like '%s' " % ", ".join(unsafeSQLIdentificatorNaming(col) for col in sorted(colList)) | ||||||
|                     else: |                     else: | ||||||
|                         infoMsg += "'%s' " % ", ".join(unsafeSQLIdentificatorNaming(col) for col in sorted(colList)) |                         infoMsg += "'%s' " % ", ".join(unsafeSQLIdentificatorNaming(col) for col in sorted(colList)) | ||||||
|                 else: |                 else: | ||||||
|  | @ -2199,24 +2199,22 @@ class Enumeration: | ||||||
|                     if foundDb is None or foundTbl is None: |                     if foundDb is None or foundTbl is None: | ||||||
|                         continue |                         continue | ||||||
| 
 | 
 | ||||||
|                     if foundDb not in dbs: |                     conf.db = foundDb | ||||||
|                         dbs[foundDb] = {} |                     conf.tbl = foundTbl | ||||||
|  |                     conf.col = column | ||||||
| 
 | 
 | ||||||
|                     if foundTbl not in dbs[foundDb]: |                     self.getColumns(onlyColNames=True, colTuple=(colConsider, colCondParam), bruteForce=False) | ||||||
|                         dbs[foundDb][foundTbl] = {} |  | ||||||
| 
 | 
 | ||||||
|                     if colConsider == "1": |                     if foundDb in kb.data.cachedColumns and foundTbl in kb.data.cachedColumns[foundDb]: | ||||||
|                         conf.db = foundDb |                         if foundDb not in dbs: | ||||||
|                         conf.tbl = foundTbl |                             dbs[foundDb] = {} | ||||||
|                         conf.col = column |  | ||||||
| 
 | 
 | ||||||
|                         self.getColumns(onlyColNames=True, colTuple=(colConsider, colCondParam), bruteForce=False) |                         if foundTbl not in dbs[foundDb]: | ||||||
|  |                             dbs[foundDb][foundTbl] = {} | ||||||
| 
 | 
 | ||||||
|                         if foundDb in kb.data.cachedColumns and foundTbl in kb.data.cachedColumns[foundDb]: |                         dbs[foundDb][foundTbl].update(kb.data.cachedColumns[foundDb][foundTbl]) | ||||||
|                             dbs[foundDb][foundTbl].update(kb.data.cachedColumns[foundDb][foundTbl]) | 
 | ||||||
|                         kb.data.cachedColumns = {} |                     kb.data.cachedColumns = {} | ||||||
|                     else: |  | ||||||
|                         dbs[foundDb][foundTbl][column] = None |  | ||||||
| 
 | 
 | ||||||
|                     if foundDb in foundCols[column]: |                     if foundDb in foundCols[column]: | ||||||
|                         foundCols[column][foundDb].append(foundTbl) |                         foundCols[column][foundDb].append(foundTbl) | ||||||
|  | @ -2263,7 +2261,6 @@ class Enumeration: | ||||||
|                             foundCols[column][db] = [] |                             foundCols[column][db] = [] | ||||||
|                 else: |                 else: | ||||||
|                     for db in conf.db.split(","): |                     for db in conf.db.split(","): | ||||||
|                         dbs[db] = {} |  | ||||||
|                         if db not in foundCols[column]: |                         if db not in foundCols[column]: | ||||||
|                             foundCols[column][db] = [] |                             foundCols[column][db] = [] | ||||||
| 
 | 
 | ||||||
|  | @ -2307,23 +2304,27 @@ class Enumeration: | ||||||
| 
 | 
 | ||||||
|                             tbl = safeSQLIdentificatorNaming(tbl, True) |                             tbl = safeSQLIdentificatorNaming(tbl, True) | ||||||
| 
 | 
 | ||||||
|                             if tbl not in dbs[db]: |                             conf.db = db | ||||||
|                                 dbs[db][tbl] = {} |                             conf.tbl = tbl | ||||||
|  |                             conf.col = column | ||||||
| 
 | 
 | ||||||
|                             if colConsider == "1": |                             self.getColumns(onlyColNames=True, colTuple=(colConsider, colCondParam), bruteForce=False) | ||||||
|                                 conf.db = db |  | ||||||
|                                 conf.tbl = tbl |  | ||||||
|                                 conf.col = column |  | ||||||
| 
 | 
 | ||||||
|                                 self.getColumns(onlyColNames=True, colTuple=(colConsider, colCondParam), bruteForce=False) |                             if db in kb.data.cachedColumns and tbl in kb.data.cachedColumns[db]: | ||||||
|  |                                 if db not in dbs: | ||||||
|  |                                     dbs[db] = {} | ||||||
| 
 | 
 | ||||||
|                                 if db in kb.data.cachedColumns and tbl in kb.data.cachedColumns[db]: |                                 if tbl not in dbs[db]: | ||||||
|                                     dbs[db][tbl].update(kb.data.cachedColumns[db][tbl]) |                                     dbs[db][tbl] = {} | ||||||
|                                 kb.data.cachedColumns = {} | 
 | ||||||
|  |                                 dbs[db][tbl].update(kb.data.cachedColumns[db][tbl]) | ||||||
|  | 
 | ||||||
|  |                             kb.data.cachedColumns = {} | ||||||
|  | 
 | ||||||
|  |                             if db in foundCols[column]: | ||||||
|  |                                 foundCols[column][db].append(tbl) | ||||||
|                             else: |                             else: | ||||||
|                                 dbs[db][tbl][column] = None |                                 foundCols[column][db] = [tbl] | ||||||
| 
 |  | ||||||
|                             foundCols[column][db].append(tbl) |  | ||||||
| 
 | 
 | ||||||
|         self.dumpFoundColumn(dbs, foundCols, colConsider) |         self.dumpFoundColumn(dbs, foundCols, colConsider) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user