Details
Description
When executing a query with a NUL byte ('\0') in it, SHOW PROCESSLIST will just show the query up to that byte, hiding the rest of the query. In the slow query log, on the other hand,
the full query is shown, and the NUL byte encoded as '^@'.
This can be used by a malicious user to try to hide SQL injection attacks.
<?php
|
$db = mysqli_connect("127.0.0.1", "root", "", "test");
|
$query = "SELECT user FROM mysql.user WHERE user = 'root\0' OR SLEEP(100)";
|
$db->query($query);
|
?>
|
> show full processlist;
|
+----+-------------+-----------------+------+---------+------+--------------------------+------------------------------------------------+----------+
|
| Id | User | Host | db | Command | Time | State | Info | Progress |
|
+----+-------------+-----------------+------+---------+------+--------------------------+------------------------------------------------+----------+
|
[...]
|
| 17 | root | localhost:41928 | NULL | Query | 0 | Init | show full processlist | 0.000 |
|
| 18 | root | localhost:41930 | test | Query | 2 | User sleep | SELECT user FROM mysql.user WHERE user = 'root | 0.000 |
|
+----+-------------+-----------------+------+---------+------+--------------------------+------------------------------------------------+----------+
|
Time Id Command Argument
|
# Time: 190902 12:22:03
|
# User@Host: root[root] @ localhost [127.0.0.1]
|
# Thread_id: 18 Schema: test QC_hit: No
|
# Query_time: 300.028394 Lock_time: 0.001831 Rows_sent: 0 Rows_examined: 3
|
# Rows_affected: 0 Bytes_sent: 70
|
use test;
|
SET timestamp=1567419723;
|
SELECT user FROM mysql.user WHERE user = 'root^@' OR SLEEP(100);
|
Attachments
Issue Links
- causes
-
MDEV-21462 main.processlist_notembedded fails to clean up, causes perfschema test failures
-
- Closed
-
- relates to
-
MDEV-22513 main.processlist_notembedded fails in buildbot with Timeout in wait_until_count_sessions
-
- Closed
-
Activity
Field | Original Value | New Value |
---|---|---|
Description |
When executing a query with a NUL byte ('\0') in it, SHOW PROCESSLIST will just show the query up to that byte, hiding the rest of the query. In the slow query log, on the other hand,
the full query is shown, and the NUL byte encoded as '^@'. This can be used by a malicious user to try to hide SQL injection attacks. {noformat} <?php $db = mysqli_connect("127.0.0.1", "root", "", "test"); $query = "SELECT user FROM mysql.user WHERE user = 'root\0' OR SLEEP(100)"; $db->query($query); ?> {noforomat} {noformat} > show full processlist; +----+-------------+-----------------+------+---------+------+--------------------------+------------------------------------------------+----------+ | Id | User | Host | db | Command | Time | State | Info | Progress | +----+-------------+-----------------+------+---------+------+--------------------------+------------------------------------------------+----------+ [...] | 17 | root | localhost:41928 | NULL | Query | 0 | Init | show full processlist | 0.000 | | 18 | root | localhost:41930 | test | Query | 2 | User sleep | SELECT user FROM mysql.user WHERE user = 'root | 0.000 | +----+-------------+-----------------+------+---------+------+--------------------------+------------------------------------------------+----------+ {noformat} {noformat} Time Id Command Argument # Time: 190902 12:22:03 # User@Host: root[root] @ localhost [127.0.0.1] # Thread_id: 18 Schema: test QC_hit: No # Query_time: 300.028394 Lock_time: 0.001831 Rows_sent: 0 Rows_examined: 3 # Rows_affected: 0 Bytes_sent: 70 use test; SET timestamp=1567419723; SELECT user FROM mysql.user WHERE user = 'root^@' OR SLEEP(100); {noformat} |
When executing a query with a NUL byte ('\0') in it, SHOW PROCESSLIST will just show the query up to that byte, hiding the rest of the query. In the slow query log, on the other hand,
the full query is shown, and the NUL byte encoded as '^@'. This can be used by a malicious user to try to hide SQL injection attacks. {noformat} <?php $db = mysqli_connect("127.0.0.1", "root", "", "test"); $query = "SELECT user FROM mysql.user WHERE user = 'root\0' OR SLEEP(100)"; $db->query($query); ?> {noformat} {noformat} > show full processlist; +----+-------------+-----------------+------+---------+------+--------------------------+------------------------------------------------+----------+ | Id | User | Host | db | Command | Time | State | Info | Progress | +----+-------------+-----------------+------+---------+------+--------------------------+------------------------------------------------+----------+ [...] | 17 | root | localhost:41928 | NULL | Query | 0 | Init | show full processlist | 0.000 | | 18 | root | localhost:41930 | test | Query | 2 | User sleep | SELECT user FROM mysql.user WHERE user = 'root | 0.000 | +----+-------------+-----------------+------+---------+------+--------------------------+------------------------------------------------+----------+ {noformat} {noformat} Time Id Command Argument # Time: 190902 12:22:03 # User@Host: root[root] @ localhost [127.0.0.1] # Thread_id: 18 Schema: test QC_hit: No # Query_time: 300.028394 Lock_time: 0.001831 Rows_sent: 0 Rows_examined: 3 # Rows_affected: 0 Bytes_sent: 70 use test; SET timestamp=1567419723; SELECT user FROM mysql.user WHERE user = 'root^@' OR SLEEP(100); {noformat} |
Affects Version/s | 10.0 [ 16000 ] | |
Affects Version/s | 10.1 [ 16100 ] | |
Affects Version/s | 10.2 [ 14601 ] | |
Affects Version/s | 10.3 [ 22126 ] | |
Affects Version/s | 10.4 [ 22408 ] |
Affects Version/s | 5.5 [ 15800 ] |
Fix Version/s | 5.5 [ 15800 ] | |
Fix Version/s | 10.0 [ 16000 ] | |
Fix Version/s | 10.1 [ 16100 ] | |
Fix Version/s | 10.2 [ 14601 ] | |
Fix Version/s | 10.3 [ 22126 ] | |
Fix Version/s | 10.4 [ 22408 ] |
Status | Open [ 1 ] | Confirmed [ 10101 ] |
Assignee | Oleksandr Byelkin [ sanja ] |
Status | Confirmed [ 10101 ] | In Progress [ 3 ] |
Component/s | OTHER [ 10125 ] | |
Fix Version/s | 5.5.66 [ 23403 ] | |
Fix Version/s | 10.1.42 [ 23407 ] | |
Fix Version/s | 10.2.28 [ 23910 ] | |
Fix Version/s | 10.3.19 [ 23908 ] | |
Fix Version/s | 10.4.9 [ 23906 ] | |
Fix Version/s | 10.2 [ 14601 ] | |
Fix Version/s | 5.5 [ 15800 ] | |
Fix Version/s | 10.0 [ 16000 ] | |
Fix Version/s | 10.1 [ 16100 ] | |
Fix Version/s | 10.3 [ 22126 ] | |
Fix Version/s | 10.4 [ 22408 ] | |
Resolution | Fixed [ 1 ] | |
Status | In Progress [ 3 ] | Closed [ 6 ] |
Link |
This issue causes |
Link |
This issue relates to |
Workflow | MariaDB v3 [ 99357 ] | MariaDB v4 [ 156688 ] |
Zendesk Related Tickets | 136292 |