mirror of
				https://github.com/sqlmapproject/sqlmap.git
				synced 2025-10-25 05:01:32 +03:00 
			
		
		
		
	Falling back to unionReadFile() when --file-read does not work against MySQL. This happens when the session user does not have INSERT privilege, required to run LOAD DATA INFILE
This commit is contained in:
		
							parent
							
								
									2b1b4c0742
								
							
						
					
					
						commit
						072e08836f
					
				|  | @ -55,22 +55,28 @@ class Filesystem(GenericFilesystem): | ||||||
|         length = inject.getValue("SELECT LENGTH(%s) FROM %s" % (self.tblField, self.fileTblName), unique=False, resumeValue=False, expected=EXPECTED.INT, charsetType=CHARSET_TYPE.DIGITS) |         length = inject.getValue("SELECT LENGTH(%s) FROM %s" % (self.tblField, self.fileTblName), unique=False, resumeValue=False, expected=EXPECTED.INT, charsetType=CHARSET_TYPE.DIGITS) | ||||||
| 
 | 
 | ||||||
|         if not isNumPosStrValue(length): |         if not isNumPosStrValue(length): | ||||||
|             errMsg = "unable to retrieve the content of the " |             warnMsg = "unable to retrieve the content of the " | ||||||
|             errMsg += "file '%s'" % rFile |             warnMsg += "file '%s'" % rFile | ||||||
|             raise sqlmapNoneDataException, errMsg |  | ||||||
| 
 | 
 | ||||||
|         length = int(length) |             if conf.direct or isTechniqueAvailable(PAYLOAD.TECHNIQUE.UNION): | ||||||
|         sustrLen = 1024 |                 warnMsg += ", going to fall-back to simpler technique" | ||||||
| 
 |                 logger.warn(warnMsg) | ||||||
|         if length > sustrLen: |                 result = self.unionReadFile(rFile) | ||||||
|             result = [] |             else: | ||||||
| 
 |                 raise sqlmapNoneDataException, warnMsg | ||||||
|             for i in xrange(1, length, sustrLen): |  | ||||||
|                 chunk = inject.getValue("SELECT MID(%s, %d, %d) FROM %s" % (self.tblField, i, sustrLen, self.fileTblName), unpack=False, unique=False, resumeValue=False, charsetType=CHARSET_TYPE.HEXADECIMAL) |  | ||||||
| 
 |  | ||||||
|                 result.append(chunk) |  | ||||||
|         else: |         else: | ||||||
|             result = inject.getValue("SELECT %s FROM %s" % (self.tblField, self.fileTblName), unique=False, resumeValue=False, charsetType=CHARSET_TYPE.HEXADECIMAL) |             length = int(length) | ||||||
|  |             sustrLen = 1024 | ||||||
|  | 
 | ||||||
|  |             if length > sustrLen: | ||||||
|  |                 result = [] | ||||||
|  | 
 | ||||||
|  |                 for i in xrange(1, length, sustrLen): | ||||||
|  |                     chunk = inject.getValue("SELECT MID(%s, %d, %d) FROM %s" % (self.tblField, i, sustrLen, self.fileTblName), unpack=False, unique=False, resumeValue=False, charsetType=CHARSET_TYPE.HEXADECIMAL) | ||||||
|  | 
 | ||||||
|  |                     result.append(chunk) | ||||||
|  |             else: | ||||||
|  |                 result = inject.getValue("SELECT %s FROM %s" % (self.tblField, self.fileTblName), unique=False, resumeValue=False, charsetType=CHARSET_TYPE.HEXADECIMAL) | ||||||
| 
 | 
 | ||||||
|         return result |         return result | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user