堆叠 注入

(1)堆叠注入是当 php 连接 mysql 进行查询时,若查询语句使用的是 mysqli_multi_query() 而不是 mysqli_query()时,就会存在堆叠注入;

就是我们可以用 ; 作分隔,然后同时执行多个语句;

(2)而union injection(联合注入)也是将两条语句合并在一起,两者之间有什么区别么?

区别就在于union 或者union all执行的语句类型是有限的,可以用来执行查询语句,而堆叠注入可以执行的是任意的语句;

eg:sqli-labs Less-43

login_user=a&login_password=a'); create table yyuu like users#&mysubmit=Login

(3)使用 mysqli_multi_query() 的一般形式:

<?php
$con=mysqli_connect("localhost","my_user","my_password","my_db");
// 检测链接
if (mysqli_connect_errno($con))
{
    echo "连接到 MySQL 失败: " . mysqli_connect_error();
}
 
$sql = "SELECT Lastname FROM Persons ORDER BY LastName;";
$sql .= "SELECT Country FROM Customers";
 
// 执行多个 SQL 语句
if (mysqli_multi_query($con,$sql))
{
    do
    {
        // 存储第一个结果集
        if ($result=mysqli_store_result($con))
        {
            while ($row=mysqli_fetch_row($result))
            {
                printf("%sn",$row[0]);
            }
            // 释放结果内存
            mysqli_free_result($result);
        }
    }
    // 相当于移动结果集的指针指向下一个结果集
    while (mysqli_next_result($con));
}
 
mysqli_close($con);
?>

(4)报错注入和堆叠注入不能同时使用;

(5)使用堆叠注入进行插入操作时,也可以插入版本信息,查询信息等;

(6)若 select 被过滤,可以:

;set @a='select * from users;';prepare execsql from @a;execute execsql;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值