CTF之SQL注入总结

第一题原理:输入一个小数,利用intval()函数返回整数的结果,使得if($_GET[id]==1024)判断不成立,执行else语句
这题我们就可以输入1024.1,intval()返回的结果就是1024,而$_GET[id]获取到的是1024.1,恰好和1024不相等
在这里插入图片描述

第二题原理:看!strcasecmp($pass, $query[pw])和$pass = md5($_POST[pass]),if语句的第二个条件满足的条件是查询的结果和md5加密后的pass相同,推出我们输入的时候应该要构造一个md5的输入
user的playload:’ and 1=0 union select ‘c4ca4238a0b923820dcc509a6f75849b’#
pass:1
这道题我觉得难在注入要查询的是一个md5的值,而不是通常的把密码无效,查询到一个指定的用户名就能获得flag
在这里插入图片描述
第三题原理:看获得flag的条件,只要查询出来的user=admin就行了
所以playload构造成admin’)#
单引号和右括号是和语句前面的单引号和左括号形成闭合
#是注释掉后面的语句,因为题目并不需要验证pw的正确性就可以取得flag
在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值