mirror of
https://github.com/sqlmapproject/sqlmap.git
synced 2025-12-06 20:51:31 +00:00
Compare commits
22 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
8bc2ace094 | ||
|
|
e1043173d7 | ||
|
|
12c472cef5 | ||
|
|
037a07ddde | ||
|
|
0e8940b0be | ||
|
|
3ad6727d0c | ||
|
|
4191b06f58 | ||
|
|
60bb973c11 | ||
|
|
0fba9b13b3 | ||
|
|
17688f6711 | ||
|
|
3b3c2a5d04 | ||
|
|
4f7614412f | ||
|
|
4efb3ea840 | ||
|
|
c2bac51c4f | ||
|
|
7d763e224a | ||
|
|
4dd362cb2c | ||
|
|
077d58c5e9 | ||
|
|
257c4d1c88 | ||
|
|
ce30fa08d6 | ||
|
|
3ca2533c39 | ||
|
|
75bfebed9d | ||
|
|
3117730d84 |
@@ -69,7 +69,8 @@ Translations
|
|||||||
* [Portuguese](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-pt-BR.md)
|
* [Portuguese](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-pt-BR.md)
|
||||||
* [Russian](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-ru-RUS.md)
|
* [Russian](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-ru-RUS.md)
|
||||||
* [Serbian](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-rs-RS.md)
|
* [Serbian](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-rs-RS.md)
|
||||||
|
* [Slovak](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-sk-SK.md)
|
||||||
* [Spanish](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-es-MX.md)
|
* [Spanish](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-es-MX.md)
|
||||||
* [Turkish](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-tr-TR.md)
|
* [Turkish](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-tr-TR.md)
|
||||||
* [Ukrainian](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-uk-UA.md)
|
* [Ukrainian](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-uk-UA.md)
|
||||||
* [Vietnamese](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-vi-VN.md)
|
* [Vietnamese](https://github.com/sqlmapproject/sqlmap/blob/master/doc/translations/README-vi-VN.md)
|
||||||
@@ -452,6 +452,763 @@ WRITEXOR
|
|||||||
YEAR_MONTH
|
YEAR_MONTH
|
||||||
ZEROFILL
|
ZEROFILL
|
||||||
|
|
||||||
|
# MySQL 8.0 keywords (reference: https://dev.mysql.com/doc/refman/8.0/en/keywords.html)
|
||||||
|
|
||||||
|
ACCESSIBLE
|
||||||
|
ACCOUNT
|
||||||
|
ACTION
|
||||||
|
ACTIVE
|
||||||
|
ADD
|
||||||
|
ADMIN
|
||||||
|
AFTER
|
||||||
|
AGAINST
|
||||||
|
AGGREGATE
|
||||||
|
ALGORITHM
|
||||||
|
ALL
|
||||||
|
ALTER
|
||||||
|
ALWAYS
|
||||||
|
ANALYSE
|
||||||
|
ANALYZE
|
||||||
|
AND
|
||||||
|
ANY
|
||||||
|
ARRAY
|
||||||
|
AS
|
||||||
|
ASC
|
||||||
|
ASCII
|
||||||
|
ASENSITIVE
|
||||||
|
AT
|
||||||
|
ATTRIBUTE
|
||||||
|
AUTHENTICATION
|
||||||
|
AUTOEXTEND_SIZE
|
||||||
|
AUTO_INCREMENT
|
||||||
|
AVG
|
||||||
|
AVG_ROW_LENGTH
|
||||||
|
BACKUP
|
||||||
|
BEFORE
|
||||||
|
BEGIN
|
||||||
|
BETWEEN
|
||||||
|
BIGINT
|
||||||
|
BINARY
|
||||||
|
BINLOG
|
||||||
|
BIT
|
||||||
|
BLOB
|
||||||
|
BLOCK
|
||||||
|
BOOL
|
||||||
|
BOOLEAN
|
||||||
|
BOTH
|
||||||
|
BTREE
|
||||||
|
BUCKETS
|
||||||
|
BULK
|
||||||
|
BY
|
||||||
|
BYTE
|
||||||
|
CACHE
|
||||||
|
CALL
|
||||||
|
CASCADE
|
||||||
|
CASCADED
|
||||||
|
CASE
|
||||||
|
CATALOG_NAME
|
||||||
|
CHAIN
|
||||||
|
CHALLENGE_RESPONSE
|
||||||
|
CHANGE
|
||||||
|
CHANGED
|
||||||
|
CHANNEL
|
||||||
|
CHAR
|
||||||
|
CHARACTER
|
||||||
|
CHARSET
|
||||||
|
CHECK
|
||||||
|
CHECKSUM
|
||||||
|
CIPHER
|
||||||
|
CLASS_ORIGIN
|
||||||
|
CLIENT
|
||||||
|
CLONE
|
||||||
|
CLOSE
|
||||||
|
COALESCE
|
||||||
|
CODE
|
||||||
|
COLLATE
|
||||||
|
COLLATION
|
||||||
|
COLUMN
|
||||||
|
COLUMNS
|
||||||
|
COLUMN_FORMAT
|
||||||
|
COLUMN_NAME
|
||||||
|
COMMENT
|
||||||
|
COMMIT
|
||||||
|
COMMITTED
|
||||||
|
COMPACT
|
||||||
|
COMPLETION
|
||||||
|
COMPONENT
|
||||||
|
COMPRESSED
|
||||||
|
COMPRESSION
|
||||||
|
CONCURRENT
|
||||||
|
CONDITION
|
||||||
|
CONNECTION
|
||||||
|
CONSISTENT
|
||||||
|
CONSTRAINT
|
||||||
|
CONSTRAINT_CATALOG
|
||||||
|
CONSTRAINT_NAME
|
||||||
|
CONSTRAINT_SCHEMA
|
||||||
|
CONTAINS
|
||||||
|
CONTEXT
|
||||||
|
CONTINUE
|
||||||
|
CONVERT
|
||||||
|
CPU
|
||||||
|
CREATE
|
||||||
|
CROSS
|
||||||
|
CUBE
|
||||||
|
CUME_DIST
|
||||||
|
CURRENT
|
||||||
|
CURRENT_DATE
|
||||||
|
CURRENT_TIME
|
||||||
|
CURRENT_TIMESTAMP
|
||||||
|
CURRENT_USER
|
||||||
|
CURSOR
|
||||||
|
CURSOR_NAME
|
||||||
|
DATA
|
||||||
|
DATABASE
|
||||||
|
DATABASES
|
||||||
|
DATAFILE
|
||||||
|
DATE
|
||||||
|
DATETIME
|
||||||
|
DAY
|
||||||
|
DAY_HOUR
|
||||||
|
DAY_MICROSECOND
|
||||||
|
DAY_MINUTE
|
||||||
|
DAY_SECOND
|
||||||
|
DEALLOCATE
|
||||||
|
DEC
|
||||||
|
DECIMAL
|
||||||
|
DECLARE
|
||||||
|
DEFAULT
|
||||||
|
DEFAULT_AUTH
|
||||||
|
DEFINER
|
||||||
|
DEFINITION
|
||||||
|
DELAYED
|
||||||
|
DELAY_KEY_WRITE
|
||||||
|
DELETE
|
||||||
|
DENSE_RANK
|
||||||
|
DESC
|
||||||
|
DESCRIBE
|
||||||
|
DESCRIPTION
|
||||||
|
DES_KEY_FILE
|
||||||
|
DETERMINISTIC
|
||||||
|
DIAGNOSTICS
|
||||||
|
DIRECTORY
|
||||||
|
DISABLE
|
||||||
|
DISCARD
|
||||||
|
DISK
|
||||||
|
DISTINCT
|
||||||
|
DISTINCTROW
|
||||||
|
DIV
|
||||||
|
DO
|
||||||
|
DOUBLE
|
||||||
|
DROP
|
||||||
|
DUAL
|
||||||
|
DUMPFILE
|
||||||
|
DUPLICATE
|
||||||
|
DYNAMIC
|
||||||
|
EACH
|
||||||
|
ELSE
|
||||||
|
ELSEIF
|
||||||
|
EMPTY
|
||||||
|
ENABLE
|
||||||
|
ENCLOSED
|
||||||
|
ENCRYPTION
|
||||||
|
END
|
||||||
|
ENDS
|
||||||
|
ENFORCED
|
||||||
|
ENGINE
|
||||||
|
ENGINES
|
||||||
|
ENGINE_ATTRIBUTE
|
||||||
|
ENUM
|
||||||
|
ERROR
|
||||||
|
ERRORS
|
||||||
|
ESCAPE
|
||||||
|
ESCAPED
|
||||||
|
EVENT
|
||||||
|
EVENTS
|
||||||
|
EVERY
|
||||||
|
EXCEPT
|
||||||
|
EXCHANGE
|
||||||
|
EXCLUDE
|
||||||
|
EXECUTE
|
||||||
|
EXISTS
|
||||||
|
EXIT
|
||||||
|
EXPANSION
|
||||||
|
EXPIRE
|
||||||
|
EXPLAIN
|
||||||
|
EXPORT
|
||||||
|
EXTENDED
|
||||||
|
EXTENT_SIZE
|
||||||
|
FACTOR
|
||||||
|
FAILED_LOGIN_ATTEMPTS
|
||||||
|
FALSE
|
||||||
|
FAST
|
||||||
|
FAULTS
|
||||||
|
FETCH
|
||||||
|
FIELDS
|
||||||
|
FILE
|
||||||
|
FILE_BLOCK_SIZE
|
||||||
|
FILTER
|
||||||
|
FINISH
|
||||||
|
FIRST
|
||||||
|
FIRST_VALUE
|
||||||
|
FIXED
|
||||||
|
FLOAT
|
||||||
|
FLOAT4
|
||||||
|
FLOAT8
|
||||||
|
FLUSH
|
||||||
|
FOLLOWING
|
||||||
|
FOLLOWS
|
||||||
|
FOR
|
||||||
|
FORCE
|
||||||
|
FOREIGN
|
||||||
|
FORMAT
|
||||||
|
FOUND
|
||||||
|
FROM
|
||||||
|
FULL
|
||||||
|
FULLTEXT
|
||||||
|
FUNCTION
|
||||||
|
GENERAL
|
||||||
|
GENERATE
|
||||||
|
GENERATED
|
||||||
|
GEOMCOLLECTION
|
||||||
|
GEOMETRY
|
||||||
|
GEOMETRYCOLLECTION
|
||||||
|
GET
|
||||||
|
GET_FORMAT
|
||||||
|
GET_MASTER_PUBLIC_KEY
|
||||||
|
GET_SOURCE_PUBLIC_KEY
|
||||||
|
GLOBAL
|
||||||
|
GRANT
|
||||||
|
GRANTS
|
||||||
|
GROUP
|
||||||
|
GROUPING
|
||||||
|
GROUPS
|
||||||
|
GROUP_REPLICATION
|
||||||
|
GTID_ONLY
|
||||||
|
HANDLER
|
||||||
|
HASH
|
||||||
|
HAVING
|
||||||
|
HELP
|
||||||
|
HIGH_PRIORITY
|
||||||
|
HISTOGRAM
|
||||||
|
HISTORY
|
||||||
|
HOST
|
||||||
|
HOSTS
|
||||||
|
HOUR
|
||||||
|
HOUR_MICROSECOND
|
||||||
|
HOUR_MINUTE
|
||||||
|
HOUR_SECOND
|
||||||
|
IDENTIFIED
|
||||||
|
IF
|
||||||
|
IGNORE
|
||||||
|
IGNORE_SERVER_IDS
|
||||||
|
IMPORT
|
||||||
|
IN
|
||||||
|
INACTIVE
|
||||||
|
INDEX
|
||||||
|
INDEXES
|
||||||
|
INFILE
|
||||||
|
INITIAL
|
||||||
|
INITIAL_SIZE
|
||||||
|
INITIATE
|
||||||
|
INNER
|
||||||
|
INOUT
|
||||||
|
INSENSITIVE
|
||||||
|
INSERT
|
||||||
|
INSERT_METHOD
|
||||||
|
INSTALL
|
||||||
|
INSTANCE
|
||||||
|
INT
|
||||||
|
INT1
|
||||||
|
INT2
|
||||||
|
INT3
|
||||||
|
INT4
|
||||||
|
INT8
|
||||||
|
INTEGER
|
||||||
|
INTERSECT
|
||||||
|
INTERVAL
|
||||||
|
INTO
|
||||||
|
INVISIBLE
|
||||||
|
INVOKER
|
||||||
|
IO
|
||||||
|
IO_AFTER_GTIDS
|
||||||
|
IO_BEFORE_GTIDS
|
||||||
|
IO_THREAD
|
||||||
|
IPC
|
||||||
|
IS
|
||||||
|
ISOLATION
|
||||||
|
ISSUER
|
||||||
|
ITERATE
|
||||||
|
JOIN
|
||||||
|
JSON
|
||||||
|
JSON_TABLE
|
||||||
|
JSON_VALUE
|
||||||
|
KEY
|
||||||
|
KEYRING
|
||||||
|
KEYS
|
||||||
|
KEY_BLOCK_SIZE
|
||||||
|
KILL
|
||||||
|
LAG
|
||||||
|
LANGUAGE
|
||||||
|
LAST
|
||||||
|
LAST_VALUE
|
||||||
|
LATERAL
|
||||||
|
LEAD
|
||||||
|
LEADING
|
||||||
|
LEAVE
|
||||||
|
LEAVES
|
||||||
|
LEFT
|
||||||
|
LESS
|
||||||
|
LEVEL
|
||||||
|
LIKE
|
||||||
|
LIMIT
|
||||||
|
LINEAR
|
||||||
|
LINES
|
||||||
|
LINESTRING
|
||||||
|
LIST
|
||||||
|
LOAD
|
||||||
|
LOCAL
|
||||||
|
LOCALTIME
|
||||||
|
LOCALTIMESTAMP
|
||||||
|
LOCK
|
||||||
|
LOCKED
|
||||||
|
LOCKS
|
||||||
|
LOGFILE
|
||||||
|
LOGS
|
||||||
|
LONG
|
||||||
|
LONGBLOB
|
||||||
|
LONGTEXT
|
||||||
|
LOOP
|
||||||
|
LOW_PRIORITY
|
||||||
|
MASTER
|
||||||
|
MASTER_AUTO_POSITION
|
||||||
|
MASTER_BIND
|
||||||
|
MASTER_COMPRESSION_ALGORITHMS
|
||||||
|
MASTER_CONNECT_RETRY
|
||||||
|
MASTER_DELAY
|
||||||
|
MASTER_HEARTBEAT_PERIOD
|
||||||
|
MASTER_HOST
|
||||||
|
MASTER_LOG_FILE
|
||||||
|
MASTER_LOG_POS
|
||||||
|
MASTER_PASSWORD
|
||||||
|
MASTER_PORT
|
||||||
|
MASTER_PUBLIC_KEY_PATH
|
||||||
|
MASTER_RETRY_COUNT
|
||||||
|
MASTER_SERVER_ID
|
||||||
|
MASTER_SSL
|
||||||
|
MASTER_SSL_CA
|
||||||
|
MASTER_SSL_CAPATH
|
||||||
|
MASTER_SSL_CERT
|
||||||
|
MASTER_SSL_CIPHER
|
||||||
|
MASTER_SSL_CRL
|
||||||
|
MASTER_SSL_CRLPATH
|
||||||
|
MASTER_SSL_KEY
|
||||||
|
MASTER_SSL_VERIFY_SERVER_CERT
|
||||||
|
MASTER_TLS_CIPHERSUITES
|
||||||
|
MASTER_TLS_VERSION
|
||||||
|
MASTER_USER
|
||||||
|
MASTER_ZSTD_COMPRESSION_LEVEL
|
||||||
|
MATCH
|
||||||
|
MAXVALUE
|
||||||
|
MAX_CONNECTIONS_PER_HOUR
|
||||||
|
MAX_QUERIES_PER_HOUR
|
||||||
|
MAX_ROWS
|
||||||
|
MAX_SIZE
|
||||||
|
MAX_UPDATES_PER_HOUR
|
||||||
|
MAX_USER_CONNECTIONS
|
||||||
|
MEDIUM
|
||||||
|
MEDIUMBLOB
|
||||||
|
MEDIUMINT
|
||||||
|
MEDIUMTEXT
|
||||||
|
MEMBER
|
||||||
|
MEMORY
|
||||||
|
MERGE
|
||||||
|
MESSAGE_TEXT
|
||||||
|
MICROSECOND
|
||||||
|
MIDDLEINT
|
||||||
|
MIGRATE
|
||||||
|
MINUTE
|
||||||
|
MINUTE_MICROSECOND
|
||||||
|
MINUTE_SECOND
|
||||||
|
MIN_ROWS
|
||||||
|
MOD
|
||||||
|
MODE
|
||||||
|
MODIFIES
|
||||||
|
MODIFY
|
||||||
|
MONTH
|
||||||
|
MULTILINESTRING
|
||||||
|
MULTIPOINT
|
||||||
|
MULTIPOLYGON
|
||||||
|
MUTEX
|
||||||
|
MYSQL_ERRNO
|
||||||
|
NAME
|
||||||
|
NAMES
|
||||||
|
NATIONAL
|
||||||
|
NATURAL
|
||||||
|
NCHAR
|
||||||
|
NDB
|
||||||
|
NDBCLUSTER
|
||||||
|
NESTED
|
||||||
|
NETWORK_NAMESPACE
|
||||||
|
NEVER
|
||||||
|
NEW
|
||||||
|
NEXT
|
||||||
|
NO
|
||||||
|
NODEGROUP
|
||||||
|
NONE
|
||||||
|
NOT
|
||||||
|
NOWAIT
|
||||||
|
NO_WAIT
|
||||||
|
NO_WRITE_TO_BINLOG
|
||||||
|
NTH_VALUE
|
||||||
|
NTILE
|
||||||
|
NULL
|
||||||
|
NULLS
|
||||||
|
NUMBER
|
||||||
|
NUMERIC
|
||||||
|
NVARCHAR
|
||||||
|
OF
|
||||||
|
OFF
|
||||||
|
OFFSET
|
||||||
|
OJ
|
||||||
|
OLD
|
||||||
|
ON
|
||||||
|
ONE
|
||||||
|
ONLY
|
||||||
|
OPEN
|
||||||
|
OPTIMIZE
|
||||||
|
OPTIMIZER_COSTS
|
||||||
|
OPTION
|
||||||
|
OPTIONAL
|
||||||
|
OPTIONALLY
|
||||||
|
OPTIONS
|
||||||
|
OR
|
||||||
|
ORDER
|
||||||
|
ORDINALITY
|
||||||
|
ORGANIZATION
|
||||||
|
OTHERS
|
||||||
|
OUT
|
||||||
|
OUTER
|
||||||
|
OUTFILE
|
||||||
|
OVER
|
||||||
|
OWNER
|
||||||
|
PACK_KEYS
|
||||||
|
PAGE
|
||||||
|
PARSER
|
||||||
|
PARTIAL
|
||||||
|
PARTITION
|
||||||
|
PARTITIONING
|
||||||
|
PARTITIONS
|
||||||
|
PASSWORD
|
||||||
|
PASSWORD_LOCK_TIME
|
||||||
|
PATH
|
||||||
|
PERCENT_RANK
|
||||||
|
PERSIST
|
||||||
|
PERSIST_ONLY
|
||||||
|
PHASE
|
||||||
|
PLUGIN
|
||||||
|
PLUGINS
|
||||||
|
PLUGIN_DIR
|
||||||
|
POINT
|
||||||
|
POLYGON
|
||||||
|
PORT
|
||||||
|
PRECEDES
|
||||||
|
PRECEDING
|
||||||
|
PRECISION
|
||||||
|
PREPARE
|
||||||
|
PRESERVE
|
||||||
|
PREV
|
||||||
|
PRIMARY
|
||||||
|
PRIVILEGES
|
||||||
|
PRIVILEGE_CHECKS_USER
|
||||||
|
PROCEDURE
|
||||||
|
PROCESS
|
||||||
|
PROCESSLIST
|
||||||
|
PROFILE
|
||||||
|
PROFILES
|
||||||
|
PROXY
|
||||||
|
PURGE
|
||||||
|
QUARTER
|
||||||
|
QUERY
|
||||||
|
QUICK
|
||||||
|
RANDOM
|
||||||
|
RANGE
|
||||||
|
RANK
|
||||||
|
READ
|
||||||
|
READS
|
||||||
|
READ_ONLY
|
||||||
|
READ_WRITE
|
||||||
|
REAL
|
||||||
|
REBUILD
|
||||||
|
RECOVER
|
||||||
|
RECURSIVE
|
||||||
|
REDOFILE
|
||||||
|
REDO_BUFFER_SIZE
|
||||||
|
REDUNDANT
|
||||||
|
REFERENCE
|
||||||
|
REFERENCES
|
||||||
|
REGEXP
|
||||||
|
REGISTRATION
|
||||||
|
RELAY
|
||||||
|
RELAYLOG
|
||||||
|
RELAY_LOG_FILE
|
||||||
|
RELAY_LOG_POS
|
||||||
|
RELAY_THREAD
|
||||||
|
RELEASE
|
||||||
|
RELOAD
|
||||||
|
REMOTE
|
||||||
|
REMOVE
|
||||||
|
RENAME
|
||||||
|
REORGANIZE
|
||||||
|
REPAIR
|
||||||
|
REPEAT
|
||||||
|
REPEATABLE
|
||||||
|
REPLACE
|
||||||
|
REPLICA
|
||||||
|
REPLICAS
|
||||||
|
REPLICATE_DO_DB
|
||||||
|
REPLICATE_DO_TABLE
|
||||||
|
REPLICATE_IGNORE_DB
|
||||||
|
REPLICATE_IGNORE_TABLE
|
||||||
|
REPLICATE_REWRITE_DB
|
||||||
|
REPLICATE_WILD_DO_TABLE
|
||||||
|
REPLICATE_WILD_IGNORE_TABLE
|
||||||
|
REPLICATION
|
||||||
|
REQUIRE
|
||||||
|
REQUIRE_ROW_FORMAT
|
||||||
|
RESET
|
||||||
|
RESIGNAL
|
||||||
|
RESOURCE
|
||||||
|
RESPECT
|
||||||
|
RESTART
|
||||||
|
RESTORE
|
||||||
|
RESTRICT
|
||||||
|
RESUME
|
||||||
|
RETAIN
|
||||||
|
RETURN
|
||||||
|
RETURNED_SQLSTATE
|
||||||
|
RETURNING
|
||||||
|
RETURNS
|
||||||
|
REUSE
|
||||||
|
REVERSE
|
||||||
|
REVOKE
|
||||||
|
RIGHT
|
||||||
|
RLIKE
|
||||||
|
ROLE
|
||||||
|
ROLLBACK
|
||||||
|
ROLLUP
|
||||||
|
ROTATE
|
||||||
|
ROUTINE
|
||||||
|
ROW
|
||||||
|
ROWS
|
||||||
|
ROW_COUNT
|
||||||
|
ROW_FORMAT
|
||||||
|
ROW_NUMBER
|
||||||
|
RTREE
|
||||||
|
SAVEPOINT
|
||||||
|
SCHEDULE
|
||||||
|
SCHEMA
|
||||||
|
SCHEMAS
|
||||||
|
SCHEMA_NAME
|
||||||
|
SECOND
|
||||||
|
SECONDARY
|
||||||
|
SECONDARY_ENGINE
|
||||||
|
SECONDARY_ENGINE_ATTRIBUTE
|
||||||
|
SECONDARY_LOAD
|
||||||
|
SECONDARY_UNLOAD
|
||||||
|
SECOND_MICROSECOND
|
||||||
|
SECURITY
|
||||||
|
SELECT
|
||||||
|
SENSITIVE
|
||||||
|
SEPARATOR
|
||||||
|
SERIAL
|
||||||
|
SERIALIZABLE
|
||||||
|
SERVER
|
||||||
|
SESSION
|
||||||
|
SET
|
||||||
|
SHARE
|
||||||
|
SHOW
|
||||||
|
SHUTDOWN
|
||||||
|
SIGNAL
|
||||||
|
SIGNED
|
||||||
|
SIMPLE
|
||||||
|
SKIP
|
||||||
|
SLAVE
|
||||||
|
SLOW
|
||||||
|
SMALLINT
|
||||||
|
SNAPSHOT
|
||||||
|
SOCKET
|
||||||
|
SOME
|
||||||
|
SONAME
|
||||||
|
SOUNDS
|
||||||
|
SOURCE
|
||||||
|
SOURCE_AUTO_POSITION
|
||||||
|
SOURCE_BIND
|
||||||
|
SOURCE_COMPRESSION_ALGORITHMS
|
||||||
|
SOURCE_CONNECT_RETRY
|
||||||
|
SOURCE_DELAY
|
||||||
|
SOURCE_HEARTBEAT_PERIOD
|
||||||
|
SOURCE_HOST
|
||||||
|
SOURCE_LOG_FILE
|
||||||
|
SOURCE_LOG_POS
|
||||||
|
SOURCE_PASSWORD
|
||||||
|
SOURCE_PORT
|
||||||
|
SOURCE_PUBLIC_KEY_PATH
|
||||||
|
SOURCE_RETRY_COUNT
|
||||||
|
SOURCE_SSL
|
||||||
|
SOURCE_SSL_CA
|
||||||
|
SOURCE_SSL_CAPATH
|
||||||
|
SOURCE_SSL_CERT
|
||||||
|
SOURCE_SSL_CIPHER
|
||||||
|
SOURCE_SSL_CRL
|
||||||
|
SOURCE_SSL_CRLPATH
|
||||||
|
SOURCE_SSL_KEY
|
||||||
|
SOURCE_SSL_VERIFY_SERVER_CERT
|
||||||
|
SOURCE_TLS_CIPHERSUITES
|
||||||
|
SOURCE_TLS_VERSION
|
||||||
|
SOURCE_USER
|
||||||
|
SOURCE_ZSTD_COMPRESSION_LEVEL
|
||||||
|
SPATIAL
|
||||||
|
SPECIFIC
|
||||||
|
SQL
|
||||||
|
SQLEXCEPTION
|
||||||
|
SQLSTATE
|
||||||
|
SQLWARNING
|
||||||
|
SQL_AFTER_GTIDS
|
||||||
|
SQL_AFTER_MTS_GAPS
|
||||||
|
SQL_BEFORE_GTIDS
|
||||||
|
SQL_BIG_RESULT
|
||||||
|
SQL_BUFFER_RESULT
|
||||||
|
SQL_CACHE
|
||||||
|
SQL_CALC_FOUND_ROWS
|
||||||
|
SQL_NO_CACHE
|
||||||
|
SQL_SMALL_RESULT
|
||||||
|
SQL_THREAD
|
||||||
|
SQL_TSI_DAY
|
||||||
|
SQL_TSI_HOUR
|
||||||
|
SQL_TSI_MINUTE
|
||||||
|
SQL_TSI_MONTH
|
||||||
|
SQL_TSI_QUARTER
|
||||||
|
SQL_TSI_SECOND
|
||||||
|
SQL_TSI_WEEK
|
||||||
|
SQL_TSI_YEAR
|
||||||
|
SRID
|
||||||
|
SSL
|
||||||
|
STACKED
|
||||||
|
START
|
||||||
|
STARTING
|
||||||
|
STARTS
|
||||||
|
STATS_AUTO_RECALC
|
||||||
|
STATS_PERSISTENT
|
||||||
|
STATS_SAMPLE_PAGES
|
||||||
|
STATUS
|
||||||
|
STOP
|
||||||
|
STORAGE
|
||||||
|
STORED
|
||||||
|
STRAIGHT_JOIN
|
||||||
|
STREAM
|
||||||
|
STRING
|
||||||
|
SUBCLASS_ORIGIN
|
||||||
|
SUBJECT
|
||||||
|
SUBPARTITION
|
||||||
|
SUBPARTITIONS
|
||||||
|
SUPER
|
||||||
|
SUSPEND
|
||||||
|
SWAPS
|
||||||
|
SWITCHES
|
||||||
|
SYSTEM
|
||||||
|
TABLE
|
||||||
|
TABLES
|
||||||
|
TABLESPACE
|
||||||
|
TABLE_CHECKSUM
|
||||||
|
TABLE_NAME
|
||||||
|
TEMPORARY
|
||||||
|
TEMPTABLE
|
||||||
|
TERMINATED
|
||||||
|
TEXT
|
||||||
|
THAN
|
||||||
|
THEN
|
||||||
|
THREAD_PRIORITY
|
||||||
|
TIES
|
||||||
|
TIME
|
||||||
|
TIMESTAMP
|
||||||
|
TIMESTAMPADD
|
||||||
|
TIMESTAMPDIFF
|
||||||
|
TINYBLOB
|
||||||
|
TINYINT
|
||||||
|
TINYTEXT
|
||||||
|
TLS
|
||||||
|
TO
|
||||||
|
TRAILING
|
||||||
|
TRANSACTION
|
||||||
|
TRIGGER
|
||||||
|
TRIGGERS
|
||||||
|
TRUE
|
||||||
|
TRUNCATE
|
||||||
|
TYPE
|
||||||
|
TYPES
|
||||||
|
UNBOUNDED
|
||||||
|
UNCOMMITTED
|
||||||
|
UNDEFINED
|
||||||
|
UNDO
|
||||||
|
UNDOFILE
|
||||||
|
UNDO_BUFFER_SIZE
|
||||||
|
UNICODE
|
||||||
|
UNINSTALL
|
||||||
|
UNION
|
||||||
|
UNIQUE
|
||||||
|
UNKNOWN
|
||||||
|
UNLOCK
|
||||||
|
UNREGISTER
|
||||||
|
UNSIGNED
|
||||||
|
UNTIL
|
||||||
|
UPDATE
|
||||||
|
UPGRADE
|
||||||
|
URL
|
||||||
|
USAGE
|
||||||
|
USE
|
||||||
|
USER
|
||||||
|
USER_RESOURCES
|
||||||
|
USE_FRM
|
||||||
|
USING
|
||||||
|
UTC_DATE
|
||||||
|
UTC_TIME
|
||||||
|
UTC_TIMESTAMP
|
||||||
|
VALIDATION
|
||||||
|
VALUE
|
||||||
|
VALUES
|
||||||
|
VARBINARY
|
||||||
|
VARCHAR
|
||||||
|
VARCHARACTER
|
||||||
|
VARIABLES
|
||||||
|
VARYING
|
||||||
|
VCPU
|
||||||
|
VIEW
|
||||||
|
VIRTUAL
|
||||||
|
VISIBLE
|
||||||
|
WAIT
|
||||||
|
WARNINGS
|
||||||
|
WEEK
|
||||||
|
WEIGHT_STRING
|
||||||
|
WHEN
|
||||||
|
WHERE
|
||||||
|
WHILE
|
||||||
|
WINDOW
|
||||||
|
WITH
|
||||||
|
WITHOUT
|
||||||
|
WORK
|
||||||
|
WRAPPER
|
||||||
|
WRITE
|
||||||
|
X509
|
||||||
|
XA
|
||||||
|
XID
|
||||||
|
XML
|
||||||
|
XOR
|
||||||
|
YEAR
|
||||||
|
YEAR_MONTH
|
||||||
|
ZEROFILL
|
||||||
|
ZONE
|
||||||
|
|
||||||
# PostgreSQL|SQL:2016|SQL:2011 reserved words (reference: https://www.postgresql.org/docs/current/sql-keywords-appendix.html)
|
# PostgreSQL|SQL:2016|SQL:2011 reserved words (reference: https://www.postgresql.org/docs/current/sql-keywords-appendix.html)
|
||||||
|
|
||||||
ABS
|
ABS
|
||||||
@@ -872,3 +1629,8 @@ XMLTABLE
|
|||||||
XMLTEXT
|
XMLTEXT
|
||||||
XMLVALIDATE
|
XMLVALIDATE
|
||||||
YEAR
|
YEAR
|
||||||
|
|
||||||
|
# Misc
|
||||||
|
|
||||||
|
ORD
|
||||||
|
MID
|
||||||
|
|||||||
@@ -1645,7 +1645,7 @@
|
|||||||
<level>5</level>
|
<level>5</level>
|
||||||
<risk>2</risk>
|
<risk>2</risk>
|
||||||
<clause>1,2,3,9</clause>
|
<clause>1,2,3,9</clause>
|
||||||
<where>1</where>
|
<where>3</where>
|
||||||
<vector>IF(([INFERENCE]),(SELECT COUNT(*) FROM INFORMATION_SCHEMA.COLUMNS A, INFORMATION_SCHEMA.COLUMNS B, INFORMATION_SCHEMA.COLUMNS C WHERE 0 XOR 1),[RANDNUM])</vector>
|
<vector>IF(([INFERENCE]),(SELECT COUNT(*) FROM INFORMATION_SCHEMA.COLUMNS A, INFORMATION_SCHEMA.COLUMNS B, INFORMATION_SCHEMA.COLUMNS C WHERE 0 XOR 1),[RANDNUM])</vector>
|
||||||
<request>
|
<request>
|
||||||
<payload>(SELECT COUNT(*) FROM INFORMATION_SCHEMA.COLUMNS A, INFORMATION_SCHEMA.COLUMNS B, INFORMATION_SCHEMA.COLUMNS C WHERE 0 XOR 1)</payload>
|
<payload>(SELECT COUNT(*) FROM INFORMATION_SCHEMA.COLUMNS A, INFORMATION_SCHEMA.COLUMNS B, INFORMATION_SCHEMA.COLUMNS C WHERE 0 XOR 1)</payload>
|
||||||
@@ -1918,7 +1918,7 @@
|
|||||||
<level>4</level>
|
<level>4</level>
|
||||||
<risk>2</risk>
|
<risk>2</risk>
|
||||||
<clause>1,2,3,9</clause>
|
<clause>1,2,3,9</clause>
|
||||||
<where>1</where>
|
<where>3</where>
|
||||||
<vector>(SELECT (CASE WHEN ([INFERENCE]) THEN REGEXP_SUBSTRING(REPEAT(RIGHT(CHAR([RANDNUM]),0),[SLEEPTIME]00000000),NULL) ELSE '[RANDSTR]' END) FROM INFORMATION_SCHEMA.SYSTEM_USERS)</vector>
|
<vector>(SELECT (CASE WHEN ([INFERENCE]) THEN REGEXP_SUBSTRING(REPEAT(RIGHT(CHAR([RANDNUM]),0),[SLEEPTIME]00000000),NULL) ELSE '[RANDSTR]' END) FROM INFORMATION_SCHEMA.SYSTEM_USERS)</vector>
|
||||||
<request>
|
<request>
|
||||||
<payload>(SELECT (CASE WHEN ([RANDNUM]=[RANDNUM]) THEN REGEXP_SUBSTRING(REPEAT(RIGHT(CHAR([RANDNUM]),0),[SLEEPTIME]00000000),NULL) ELSE '[RANDSTR]' END) FROM INFORMATION_SCHEMA.SYSTEM_USERS)</payload>
|
<payload>(SELECT (CASE WHEN ([RANDNUM]=[RANDNUM]) THEN REGEXP_SUBSTRING(REPEAT(RIGHT(CHAR([RANDNUM]),0),[SLEEPTIME]00000000),NULL) ELSE '[RANDSTR]' END) FROM INFORMATION_SCHEMA.SYSTEM_USERS)</payload>
|
||||||
@@ -1938,7 +1938,7 @@
|
|||||||
<level>5</level>
|
<level>5</level>
|
||||||
<risk>2</risk>
|
<risk>2</risk>
|
||||||
<clause>1,2,3,9</clause>
|
<clause>1,2,3,9</clause>
|
||||||
<where>1</where>
|
<where>3</where>
|
||||||
<vector>(SELECT (CASE WHEN ([INFERENCE]) THEN REGEXP_SUBSTRING(REPEAT(LEFT(CRYPT_KEY('AES',NULL),0),[SLEEPTIME]00000000),NULL) ELSE '[RANDSTR]' END) FROM (VALUES(0)))</vector>
|
<vector>(SELECT (CASE WHEN ([INFERENCE]) THEN REGEXP_SUBSTRING(REPEAT(LEFT(CRYPT_KEY('AES',NULL),0),[SLEEPTIME]00000000),NULL) ELSE '[RANDSTR]' END) FROM (VALUES(0)))</vector>
|
||||||
<request>
|
<request>
|
||||||
<payload>(SELECT (CASE WHEN ([RANDNUM]=[RANDNUM]) THEN REGEXP_SUBSTRING(REPEAT(LEFT(CRYPT_KEY('AES',NULL),0),[SLEEPTIME]00000000),NULL) ELSE '[RANDSTR]' END) FROM (VALUES(0)))</payload>
|
<payload>(SELECT (CASE WHEN ([RANDNUM]=[RANDNUM]) THEN REGEXP_SUBSTRING(REPEAT(LEFT(CRYPT_KEY('AES',NULL),0),[SLEEPTIME]00000000),NULL) ELSE '[RANDSTR]' END) FROM (VALUES(0)))</payload>
|
||||||
|
|||||||
50
doc/translations/README-sk-SK.md
Normal file
50
doc/translations/README-sk-SK.md
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
# sqlmap 
|
||||||
|
|
||||||
|
[](https://github.com/sqlmapproject/sqlmap/actions/workflows/tests.yml) [](https://www.python.org/) [](https://raw.githubusercontent.com/sqlmapproject/sqlmap/master/LICENSE) [](https://twitter.com/sqlmap)
|
||||||
|
|
||||||
|
sqlmap je open source nástroj na penetračné testovanie, ktorý automatizuje proces detekovania a využívania chýb SQL injekcie a preberania databázových serverov. Je vybavený výkonným detekčným mechanizmom, mnohými výklenkovými funkciami pre dokonalého penetračného testera a širokou škálou prepínačov vrátane odtlačkov databázy, cez načítanie údajov z databázy, prístup k základnému súborovému systému a vykonávanie príkazov v operačnom systéme prostredníctvom mimopásmových pripojení.
|
||||||
|
|
||||||
|
Snímky obrazovky
|
||||||
|
----
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
Môžete navštíviť [zbierku snímok obrazovky](https://github.com/sqlmapproject/sqlmap/wiki/Screenshots), ktorá demonštruuje niektoré funkcie na wiki.
|
||||||
|
|
||||||
|
Inštalácia
|
||||||
|
----
|
||||||
|
|
||||||
|
Najnovší tarball si môžete stiahnuť kliknutím [sem](https://github.com/sqlmapproject/sqlmap/tarball/master) alebo najnovší zipball kliknutím [sem](https://github.com/sqlmapproject/sqlmap/zipball/master).
|
||||||
|
|
||||||
|
Najlepšie je stiahnuť sqlmap naklonovaním [Git](https://github.com/sqlmapproject/sqlmap) repozitára:
|
||||||
|
|
||||||
|
git clone --depth 1 https://github.com/sqlmapproject/sqlmap.git sqlmap-dev
|
||||||
|
|
||||||
|
sqlmap funguje bez problémov s programovacím jazykom [Python](https://www.python.org/download/) vo verziách **2.6**, **2.7** a **3.x** na akejkoľvek platforme.
|
||||||
|
|
||||||
|
Využitie
|
||||||
|
----
|
||||||
|
|
||||||
|
Na získanie zoznamu základných možností a prepínačov, použite:
|
||||||
|
|
||||||
|
python sqlmap.py -h
|
||||||
|
|
||||||
|
Na získanie zoznamu všetkých možností a prepínačov, použite:
|
||||||
|
|
||||||
|
python sqlmap.py -hh
|
||||||
|
|
||||||
|
Vzorku behu nájdete [tu](https://asciinema.org/a/46601).
|
||||||
|
Ak chcete získať prehľad o možnostiach sqlmap, zoznam podporovaných funkcií a opis všetkých možností a prepínačov spolu s príkladmi, odporúčame vám nahliadnuť do [Používateľskej príručky](https://github.com/sqlmapproject/sqlmap/wiki/Usage).
|
||||||
|
|
||||||
|
Linky
|
||||||
|
----
|
||||||
|
|
||||||
|
* Domovská stránka: https://sqlmap.org
|
||||||
|
* Stiahnutia: [.tar.gz](https://github.com/sqlmapproject/sqlmap/tarball/master) alebo [.zip](https://github.com/sqlmapproject/sqlmap/zipball/master)
|
||||||
|
* Zdroje RSS Commits: https://github.com/sqlmapproject/sqlmap/commits/master.atom
|
||||||
|
* Sledovač problémov: https://github.com/sqlmapproject/sqlmap/issues
|
||||||
|
* Používateľská príručka: https://github.com/sqlmapproject/sqlmap/wiki
|
||||||
|
* Často kladené otázky (FAQ): https://github.com/sqlmapproject/sqlmap/wiki/FAQ
|
||||||
|
* Twitter: [@sqlmap](https://twitter.com/sqlmap)
|
||||||
|
* Demá: [https://www.youtube.com/user/inquisb/videos](https://www.youtube.com/user/inquisb/videos)
|
||||||
|
* Snímky obrazovky: https://github.com/sqlmapproject/sqlmap/wiki/Screenshots
|
||||||
@@ -23,7 +23,7 @@ Veya tercihen, [Git](https://github.com/sqlmapproject/sqlmap) reposunu klonlayar
|
|||||||
|
|
||||||
git clone --depth 1 https://github.com/sqlmapproject/sqlmap.git sqlmap-dev
|
git clone --depth 1 https://github.com/sqlmapproject/sqlmap.git sqlmap-dev
|
||||||
|
|
||||||
sqlmap [Python](https://www.python.org/download/) sitesinde bulunan **2.6**, **2.7** and **3.x** versiyonları ile bütün platformlarda çalışabilmektedir.
|
sqlmap [Python](https://www.python.org/download/) sitesinde bulunan **2.6**, **2.7** ve **3.x** versiyonları ile bütün platformlarda çalışabilmektedir.
|
||||||
|
|
||||||
Kullanım
|
Kullanım
|
||||||
----
|
----
|
||||||
|
|||||||
@@ -1769,7 +1769,7 @@ def parseTargetUrl():
|
|||||||
errMsg = "invalid target URL port (%d)" % conf.port
|
errMsg = "invalid target URL port (%d)" % conf.port
|
||||||
raise SqlmapSyntaxException(errMsg)
|
raise SqlmapSyntaxException(errMsg)
|
||||||
|
|
||||||
conf.url = getUnicode("%s://%s:%d%s" % (conf.scheme, ("[%s]" % conf.hostname) if conf.ipv6 else conf.hostname, conf.port, conf.path))
|
conf.url = getUnicode("%s://%s%s%s" % (conf.scheme, ("[%s]" % conf.hostname) if conf.ipv6 else conf.hostname, (":%d" % conf.port) if not (conf.port == 80 and conf.scheme == "http" or conf.port == 443 and conf.scheme == "https") else "", conf.path))
|
||||||
conf.url = conf.url.replace(URI_QUESTION_MARKER, '?')
|
conf.url = conf.url.replace(URI_QUESTION_MARKER, '?')
|
||||||
|
|
||||||
if urlSplit.query:
|
if urlSplit.query:
|
||||||
@@ -5385,11 +5385,12 @@ def parseRequestFile(reqFile, checkParams=True):
|
|||||||
elif key.upper() == HTTP_HEADER.HOST.upper():
|
elif key.upper() == HTTP_HEADER.HOST.upper():
|
||||||
if '://' in value:
|
if '://' in value:
|
||||||
scheme, value = value.split('://')[:2]
|
scheme, value = value.split('://')[:2]
|
||||||
splitValue = value.split(":")
|
|
||||||
host = splitValue[0]
|
|
||||||
|
|
||||||
if len(splitValue) > 1:
|
port = extractRegexResult(r":(?P<result>\d+)\Z", value)
|
||||||
port = filterStringValue(splitValue[1], "[0-9]")
|
if port:
|
||||||
|
value = value[:-(1 + len(port))]
|
||||||
|
|
||||||
|
host = value
|
||||||
|
|
||||||
# Avoid to add a static content length header to
|
# Avoid to add a static content length header to
|
||||||
# headers and consider the following lines as
|
# headers and consider the following lines as
|
||||||
|
|||||||
@@ -815,7 +815,7 @@ def _setTamperingFunctions():
|
|||||||
priority = PRIORITY.NORMAL if not hasattr(module, "__priority__") else module.__priority__
|
priority = PRIORITY.NORMAL if not hasattr(module, "__priority__") else module.__priority__
|
||||||
|
|
||||||
for name, function in inspect.getmembers(module, inspect.isfunction):
|
for name, function in inspect.getmembers(module, inspect.isfunction):
|
||||||
if name == "tamper" and (hasattr(inspect, "signature") and all(_ in inspect.signature(function).parameters for _ in ("payload", "kwargs")) or hasattr(inspect, "getargspec") and inspect.getargspec(function).args and inspect.getargspec(function).keywords == "kwargs"):
|
if name == "tamper" and (hasattr(inspect, "signature") and all(_ in inspect.signature(function).parameters for _ in ("payload", "kwargs")) or inspect.getargspec(function).args and inspect.getargspec(function).keywords == "kwargs"):
|
||||||
found = True
|
found = True
|
||||||
kb.tamperFunctions.append(function)
|
kb.tamperFunctions.append(function)
|
||||||
function.__name__ = module.__name__
|
function.__name__ = module.__name__
|
||||||
|
|||||||
@@ -6,6 +6,8 @@ See the file 'LICENSE' for copying permission
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
import codecs
|
import codecs
|
||||||
|
import collections
|
||||||
|
import inspect
|
||||||
import os
|
import os
|
||||||
import random
|
import random
|
||||||
import re
|
import re
|
||||||
@@ -93,6 +95,26 @@ def dirtyPatches():
|
|||||||
else:
|
else:
|
||||||
os.urandom = lambda size: "".join(chr(random.randint(0, 255)) for _ in xrange(size))
|
os.urandom = lambda size: "".join(chr(random.randint(0, 255)) for _ in xrange(size))
|
||||||
|
|
||||||
|
# Reference: https://github.com/bottlepy/bottle/blob/df67999584a0e51ec5b691146c7fa4f3c87f5aac/bottle.py
|
||||||
|
# Reference: https://python.readthedocs.io/en/v2.7.2/library/inspect.html#inspect.getargspec
|
||||||
|
if not hasattr(inspect, "getargspec") and hasattr(inspect, "getfullargspec"):
|
||||||
|
ArgSpec = collections.namedtuple("ArgSpec", ("args", "varargs", "keywords", "defaults"))
|
||||||
|
|
||||||
|
def makelist(data):
|
||||||
|
if isinstance(data, (tuple, list, set, dict)):
|
||||||
|
return list(data)
|
||||||
|
elif data:
|
||||||
|
return [data]
|
||||||
|
else:
|
||||||
|
return []
|
||||||
|
|
||||||
|
def getargspec(func):
|
||||||
|
spec = inspect.getfullargspec(func)
|
||||||
|
kwargs = makelist(spec[0]) + makelist(spec.kwonlyargs)
|
||||||
|
return ArgSpec(kwargs, spec[1], spec[2], spec[3])
|
||||||
|
|
||||||
|
inspect.getargspec = getargspec
|
||||||
|
|
||||||
def resolveCrossReferences():
|
def resolveCrossReferences():
|
||||||
"""
|
"""
|
||||||
Place for cross-reference resolution
|
Place for cross-reference resolution
|
||||||
|
|||||||
@@ -20,7 +20,7 @@ from thirdparty import six
|
|||||||
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.7.3.0"
|
VERSION = "1.7.5.0"
|
||||||
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)
|
||||||
|
|||||||
@@ -156,7 +156,8 @@ def _setRequestParams():
|
|||||||
if not (kb.processUserMarks and kb.customInjectionMark in conf.data):
|
if not (kb.processUserMarks and kb.customInjectionMark in conf.data):
|
||||||
conf.data = getattr(conf.data, UNENCODED_ORIGINAL_VALUE, conf.data)
|
conf.data = getattr(conf.data, UNENCODED_ORIGINAL_VALUE, conf.data)
|
||||||
conf.data = conf.data.replace(kb.customInjectionMark, ASTERISK_MARKER)
|
conf.data = conf.data.replace(kb.customInjectionMark, ASTERISK_MARKER)
|
||||||
conf.data = re.sub(r'("(?P<name>[^"]+)"\s*:\s*".+?)"(?<!\\")', functools.partial(process, repl=r'\g<1>%s"' % kb.customInjectionMark), conf.data)
|
conf.data = re.sub(r'("(?P<name>[^"]+)"\s*:\s*".*?)"(?<!\\")', functools.partial(process, repl=r'\g<1>%s"' % kb.customInjectionMark), conf.data)
|
||||||
|
conf.data = re.sub(r'("(?P<name>[^"]+)"\s*:\s*")"', functools.partial(process, repl=r'\g<1>%s"' % kb.customInjectionMark), conf.data)
|
||||||
conf.data = re.sub(r'("(?P<name>[^"]+)"\s*:\s*)(-?\d[\d\.]*)\b', functools.partial(process, repl=r'\g<1>\g<3>%s' % kb.customInjectionMark), conf.data)
|
conf.data = re.sub(r'("(?P<name>[^"]+)"\s*:\s*)(-?\d[\d\.]*)\b', functools.partial(process, repl=r'\g<1>\g<3>%s' % kb.customInjectionMark), conf.data)
|
||||||
conf.data = re.sub(r'("(?P<name>[^"]+)"\s*:\s*)((true|false|null))\b', functools.partial(process, repl=r'\g<1>\g<3>%s' % kb.customInjectionMark), conf.data)
|
conf.data = re.sub(r'("(?P<name>[^"]+)"\s*:\s*)((true|false|null))\b', functools.partial(process, repl=r'\g<1>\g<3>%s' % kb.customInjectionMark), conf.data)
|
||||||
for match in re.finditer(r'(?P<name>[^"]+)"\s*:\s*\[([^\]]+)\]', conf.data):
|
for match in re.finditer(r'(?P<name>[^"]+)"\s*:\s*\[([^\]]+)\]', conf.data):
|
||||||
|
|||||||
@@ -71,7 +71,7 @@ def update():
|
|||||||
logger.warning(warnMsg)
|
logger.warning(warnMsg)
|
||||||
|
|
||||||
if VERSION == getLatestRevision():
|
if VERSION == getLatestRevision():
|
||||||
logger.info("already at the latest revision '%s'" % getRevisionNumber())
|
logger.info("already at the latest revision '%s'" % (getRevisionNumber() or VERSION))
|
||||||
return
|
return
|
||||||
|
|
||||||
message = "do you want to try to fetch the latest 'zipball' from repository and extract it (experimental) ? [y/N]"
|
message = "do you want to try to fetch the latest 'zipball' from repository and extract it (experimental) ? [y/N]"
|
||||||
|
|||||||
@@ -814,7 +814,7 @@ class Connect(object):
|
|||||||
debugMsg = "got HTTP error code: %d ('%s')" % (code, status)
|
debugMsg = "got HTTP error code: %d ('%s')" % (code, status)
|
||||||
logger.debug(debugMsg)
|
logger.debug(debugMsg)
|
||||||
|
|
||||||
except (_urllib.error.URLError, socket.error, socket.timeout, _http_client.HTTPException, struct.error, binascii.Error, ProxyError, SqlmapCompressionException, WebSocketException, TypeError, ValueError, OverflowError, AttributeError, OSError):
|
except (_urllib.error.URLError, socket.error, socket.timeout, _http_client.HTTPException, struct.error, binascii.Error, ProxyError, SqlmapCompressionException, WebSocketException, TypeError, ValueError, OverflowError, AttributeError, OSError, AssertionError):
|
||||||
tbMsg = traceback.format_exc()
|
tbMsg = traceback.format_exc()
|
||||||
|
|
||||||
if conf.debug:
|
if conf.debug:
|
||||||
@@ -1333,7 +1333,7 @@ class Connect(object):
|
|||||||
compile(getBytes(re.sub(r"\s*;\s*", "\n", conf.evalCode)), "", "exec")
|
compile(getBytes(re.sub(r"\s*;\s*", "\n", conf.evalCode)), "", "exec")
|
||||||
except SyntaxError as ex:
|
except SyntaxError as ex:
|
||||||
if ex.text:
|
if ex.text:
|
||||||
original = replacement = ex.text.strip()
|
original = replacement = getUnicode(ex.text.strip())
|
||||||
|
|
||||||
if '=' in original:
|
if '=' in original:
|
||||||
name, value = original.split('=', 1)
|
name, value = original.split('=', 1)
|
||||||
|
|||||||
@@ -27,7 +27,7 @@ try:
|
|||||||
except ImportError:
|
except ImportError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
_protocols = filterNone(getattr(ssl, _, None) for _ in ("PROTOCOL_TLSv1_2", "PROTOCOL_TLSv1_1", "PROTOCOL_TLSv1", "PROTOCOL_SSLv3", "PROTOCOL_SSLv23", "PROTOCOL_SSLv2"))
|
_protocols = filterNone(getattr(ssl, _, None) for _ in ("PROTOCOL_TLS_CLIENT", "PROTOCOL_TLSv1_2", "PROTOCOL_TLSv1_1", "PROTOCOL_TLSv1", "PROTOCOL_SSLv3", "PROTOCOL_SSLv23", "PROTOCOL_SSLv2"))
|
||||||
_lut = dict((getattr(ssl, _), _) for _ in dir(ssl) if _.startswith("PROTOCOL_"))
|
_lut = dict((getattr(ssl, _), _) for _ in dir(ssl) if _.startswith("PROTOCOL_"))
|
||||||
_contexts = {}
|
_contexts = {}
|
||||||
|
|
||||||
@@ -69,6 +69,11 @@ class HTTPSConnection(_http_client.HTTPSConnection):
|
|||||||
sock = create_sock()
|
sock = create_sock()
|
||||||
if protocol not in _contexts:
|
if protocol not in _contexts:
|
||||||
_contexts[protocol] = ssl.SSLContext(protocol)
|
_contexts[protocol] = ssl.SSLContext(protocol)
|
||||||
|
|
||||||
|
# Disable certificate and hostname validation enabled by default with PROTOCOL_TLS_CLIENT
|
||||||
|
_contexts[protocol].check_hostname = False
|
||||||
|
_contexts[protocol].verify_mode = ssl.CERT_NONE
|
||||||
|
|
||||||
if getattr(self, "cert_file", None) and getattr(self, "key_file", None):
|
if getattr(self, "cert_file", None) and getattr(self, "key_file", None):
|
||||||
_contexts[protocol].load_cert_chain(certfile=self.cert_file, keyfile=self.key_file)
|
_contexts[protocol].load_cert_chain(certfile=self.cert_file, keyfile=self.key_file)
|
||||||
try:
|
try:
|
||||||
|
|||||||
@@ -66,7 +66,7 @@ class SmartRedirectHandler(_urllib.request.HTTPRedirectHandler):
|
|||||||
self.redirect_request = self._redirect_request
|
self.redirect_request = self._redirect_request
|
||||||
|
|
||||||
def _redirect_request(self, req, fp, code, msg, headers, newurl):
|
def _redirect_request(self, req, fp, code, msg, headers, newurl):
|
||||||
return _urllib.request.Request(newurl.replace(' ', '%20'), data=req.data, headers=req.headers, origin_req_host=req.get_origin_req_host())
|
return _urllib.request.Request(newurl.replace(' ', '%20'), data=req.data, headers=req.headers, origin_req_host=req.get_origin_req_host() if hasattr(req, "get_origin_req_host") else req.origin_req_host)
|
||||||
|
|
||||||
def http_error_302(self, req, fp, code, msg, headers):
|
def http_error_302(self, req, fp, code, msg, headers):
|
||||||
start = time.time()
|
start = time.time()
|
||||||
|
|||||||
@@ -7,7 +7,6 @@ See the file 'LICENSE' for copying permission
|
|||||||
|
|
||||||
from __future__ import division
|
from __future__ import division
|
||||||
|
|
||||||
import logging
|
|
||||||
import time
|
import time
|
||||||
|
|
||||||
from lib.core.common import Backend
|
from lib.core.common import Backend
|
||||||
@@ -387,9 +386,6 @@ def fileExists(pathFile):
|
|||||||
kb.locks.io.release()
|
kb.locks.io.release()
|
||||||
|
|
||||||
try:
|
try:
|
||||||
pushValue(logger.getEffectiveLevel())
|
|
||||||
logger.setLevel(logging.CRITICAL)
|
|
||||||
|
|
||||||
runThreads(conf.threads, fileExistsThread, threadChoice=True)
|
runThreads(conf.threads, fileExistsThread, threadChoice=True)
|
||||||
except KeyboardInterrupt:
|
except KeyboardInterrupt:
|
||||||
warnMsg = "user aborted during file existence "
|
warnMsg = "user aborted during file existence "
|
||||||
@@ -397,7 +393,6 @@ def fileExists(pathFile):
|
|||||||
logger.warning(warnMsg)
|
logger.warning(warnMsg)
|
||||||
finally:
|
finally:
|
||||||
kb.bruteMode = False
|
kb.bruteMode = False
|
||||||
logger.setLevel(popValue())
|
|
||||||
|
|
||||||
clearConsoleLine(True)
|
clearConsoleLine(True)
|
||||||
dataToStdout("\n")
|
dataToStdout("\n")
|
||||||
|
|||||||
@@ -21,13 +21,13 @@ class Filesystem(GenericFilesystem):
|
|||||||
|
|
||||||
@stackedmethod
|
@stackedmethod
|
||||||
def stackedWriteFile(self, localFile, remoteFile, fileType=None, forceCheck=False):
|
def stackedWriteFile(self, localFile, remoteFile, fileType=None, forceCheck=False):
|
||||||
funcName = randomStr()
|
func_name = randomStr()
|
||||||
max_bytes = 1024 * 1024
|
max_bytes = 1024 * 1024
|
||||||
|
|
||||||
debugMsg = "creating JLP procedure '%s'" % funcName
|
debugMsg = "creating JLP procedure '%s'" % func_name
|
||||||
logger.debug(debugMsg)
|
logger.debug(debugMsg)
|
||||||
|
|
||||||
addFuncQuery = "CREATE PROCEDURE %s (IN paramString VARCHAR, IN paramArrayOfByte VARBINARY(%s)) " % (funcName, max_bytes)
|
addFuncQuery = "CREATE PROCEDURE %s (IN paramString VARCHAR, IN paramArrayOfByte VARBINARY(%s)) " % (func_name, max_bytes)
|
||||||
addFuncQuery += "LANGUAGE JAVA DETERMINISTIC NO SQL "
|
addFuncQuery += "LANGUAGE JAVA DETERMINISTIC NO SQL "
|
||||||
addFuncQuery += "EXTERNAL NAME 'CLASSPATH:com.sun.org.apache.xml.internal.security.utils.JavaUtils.writeBytesToFilename'"
|
addFuncQuery += "EXTERNAL NAME 'CLASSPATH:com.sun.org.apache.xml.internal.security.utils.JavaUtils.writeBytesToFilename'"
|
||||||
inject.goStacked(addFuncQuery)
|
inject.goStacked(addFuncQuery)
|
||||||
@@ -47,11 +47,12 @@ class Filesystem(GenericFilesystem):
|
|||||||
logger.debug(debugMsg)
|
logger.debug(debugMsg)
|
||||||
|
|
||||||
# Reference: http://hsqldb.org/doc/guide/sqlroutines-chapt.html#src_jrt_procedures
|
# Reference: http://hsqldb.org/doc/guide/sqlroutines-chapt.html#src_jrt_procedures
|
||||||
invokeQuery = "CALL %s('%s', CAST('%s' AS VARBINARY(%s)))" % (funcName, remoteFile, fcEncodedStr, max_bytes)
|
invokeQuery = "CALL %s('%s', CAST('%s' AS VARBINARY(%s)))" % (func_name, remoteFile, fcEncodedStr, max_bytes)
|
||||||
inject.goStacked(invokeQuery)
|
inject.goStacked(invokeQuery)
|
||||||
|
|
||||||
logger.debug("cleaning up" % funcName)
|
logger.debug("cleaning up the database management system")
|
||||||
delQuery = "DELETE PROCEDURE %s" % funcName
|
|
||||||
|
delQuery = "DELETE PROCEDURE %s" % func_name
|
||||||
inject.goStacked(delQuery)
|
inject.goStacked(delQuery)
|
||||||
|
|
||||||
message = "the local file '%s' has been written on the back-end DBMS" % localFile
|
message = "the local file '%s' has been written on the back-end DBMS" % localFile
|
||||||
|
|||||||
@@ -222,13 +222,13 @@ class Filesystem(object):
|
|||||||
|
|
||||||
if conf.direct or isStackingAvailable():
|
if conf.direct or isStackingAvailable():
|
||||||
if isStackingAvailable():
|
if isStackingAvailable():
|
||||||
debugMsg = "going to read the file with stacked query SQL "
|
debugMsg = "going to try to read the file with stacked query SQL "
|
||||||
debugMsg += "injection technique"
|
debugMsg += "injection technique"
|
||||||
logger.debug(debugMsg)
|
logger.debug(debugMsg)
|
||||||
|
|
||||||
fileContent = self.stackedReadFile(remoteFile)
|
fileContent = self.stackedReadFile(remoteFile)
|
||||||
elif Backend.isDbms(DBMS.MYSQL):
|
elif Backend.isDbms(DBMS.MYSQL):
|
||||||
debugMsg = "going to read the file with a non-stacked query "
|
debugMsg = "going to try to read the file with non-stacked query "
|
||||||
debugMsg += "SQL injection technique"
|
debugMsg += "SQL injection technique"
|
||||||
logger.debug(debugMsg)
|
logger.debug(debugMsg)
|
||||||
|
|
||||||
|
|||||||
@@ -472,6 +472,11 @@ def main():
|
|||||||
logger.critical(errMsg)
|
logger.critical(errMsg)
|
||||||
raise SystemExit
|
raise SystemExit
|
||||||
|
|
||||||
|
elif all(_ in excMsg for _ in ("FileNotFoundError: [Errno 2] No such file or directory", "cwd = os.getcwd()")):
|
||||||
|
errMsg = "invalid runtime environment ('%s')" % excMsg.split("Error: ")[-1].strip()
|
||||||
|
logger.critical(errMsg)
|
||||||
|
raise SystemExit
|
||||||
|
|
||||||
elif all(_ in excMsg for _ in ("PermissionError: [WinError 5]", "multiprocessing")):
|
elif all(_ in excMsg for _ in ("PermissionError: [WinError 5]", "multiprocessing")):
|
||||||
errMsg = "there is a permission problem in running multiprocessing on this system. "
|
errMsg = "there is a permission problem in running multiprocessing on this system. "
|
||||||
errMsg += "Please rerun with '--disable-multi'"
|
errMsg += "Please rerun with '--disable-multi'"
|
||||||
@@ -548,7 +553,7 @@ def main():
|
|||||||
finally:
|
finally:
|
||||||
kb.threadContinue = False
|
kb.threadContinue = False
|
||||||
|
|
||||||
if getDaysFromLastUpdate() > LAST_UPDATE_NAGGING_DAYS:
|
if (getDaysFromLastUpdate() or 0) > LAST_UPDATE_NAGGING_DAYS:
|
||||||
warnMsg = "your sqlmap version is outdated"
|
warnMsg = "your sqlmap version is outdated"
|
||||||
logger.warning(warnMsg)
|
logger.warning(warnMsg)
|
||||||
|
|
||||||
|
|||||||
2
thirdparty/socks/socks.py
vendored
2
thirdparty/socks/socks.py
vendored
@@ -195,7 +195,7 @@ class socksocket(socket.socket):
|
|||||||
elif chosenauth[1:2] == chr(0x02).encode():
|
elif chosenauth[1:2] == chr(0x02).encode():
|
||||||
# Okay, we need to perform a basic username/password
|
# Okay, we need to perform a basic username/password
|
||||||
# authentication.
|
# authentication.
|
||||||
self.sendall(chr(0x01).encode() + chr(len(self.__proxy[4])) + self.__proxy[4] + chr(len(self.__proxy[5])) + self.__proxy[5])
|
self.sendall(chr(0x01).encode() + chr(len(self.__proxy[4])).encode() + self.__proxy[4].encode() + chr(len(self.__proxy[5])).encode() + self.__proxy[5].encode())
|
||||||
authstat = self.__recvall(2)
|
authstat = self.__recvall(2)
|
||||||
if authstat[0:1] != chr(0x01).encode():
|
if authstat[0:1] != chr(0x01).encode():
|
||||||
# Bad response
|
# Bad response
|
||||||
|
|||||||
Reference in New Issue
Block a user