[BJDCTF2020]Mark loves cat -wp

在这里插入图片描述
页面打开后长这样。
扫描器扫一下,发现是git泄露。
用githack提取一下
在这里插入图片描述

flag.php
在这里插入图片描述
index.php

<?php

include 'flag.php';

$yds = "dog";
$is = "cat";
$handsome = 'yds';

foreach($_POST as $x => $y){
    $$x = $y;       
}

foreach($_GET as $x => $y){
    $$x = $$y;         
}

foreach($_GET as $x => $y){
    if($_GET['flag'] === $x && $x !== 'flag'){
        exit($handsome);
    }
}

if(!isset($_GET['flag']) && !isset($_POST['flag'])){
    exit($yds);
}

if($_POST['flag'] === 'flag'  || $_GET['flag'] === 'flag'){
    exit($is);
}




echo "the flag is: ".$flag;

审计一下代码,出现$$的变量覆盖比较多。

include ‘flag.php’;的意思就是告诉$flag就是真正的flag

$yds = "dog";

foreach($_GET as $x => $y){
    $$x = $$y;         
}
if(!isset($_GET['flag']) && !isset($_POST['flag'])){
    exit($yds);
}

研究一下这几行代码,它会对get传参进行遍历。
当我们get传yds=flag时,就会变成$yds=$flag,也就真正的flag赋值给了$yds,而下面的判断条件是,不传flag参数就输出$yds,那么就变成了输出flag。
所以get传参yds=flag即可
在这里插入图片描述
多研究一下发现

?is=flag&flag=flag

也能出flag

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值