CTFSHOW 入门web105

web105

源码

highlight_file(__FILE__);
include('flag.php');
error_reporting(0);  关闭报错
$error='你还想要flag嘛?';
$suces='既然你想要那给你吧!';
foreach($_GET as $key => $value){ 遍历GET参数
    if($key==='error'){
        die("what are you doing?!");
    }
    $$key=$$value;
}foreach($_POST as $key => $value){
    if($value==='flag'){
        die("what are you doing?!");
    }
    $$key=$$value;
}
if(!($_POST['flag']==$flag)){
    die($error);
}
echo "your are good".$flag."\n";
die($suces);
​
?>
&&应用
$hell="abc";
$$hell="def";等同于$abc="def";

这里的&&把key的值变为了变量所以可以通过$error和$$suces进行输入flag

方法1

第一个if语句GET的值不能等于error,第二个if把flag过滤掉了。

可以把两个结合起来进行绕过先在GET里传入一个值为flag的变量然后在POST里获得从GET中传入的变量

方法2

通过suces来获取flag,GET传入suces=flag,下面还有一个if语句需要绕过if(!($_POST['flag']==$flag)),所以还要传入一个变量flag来绕过

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值