当前位置: 代码迷 >> 综合 >> 第四十一题——BJDCTF2020]Mark loves cat
  详细解决方案

第四十一题——BJDCTF2020]Mark loves cat

热度:65   发布时间:2023-11-19 19:37:12.0

题目地址:https://buuoj.cn/challenges

解题思路

第一步:进入题目,没有任何提示,使用dirsearch扫描出了/.git路径,使用GitHack获取/.git下的内容,发现了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;

第二步:代码审计

  1. foreach将as前的参数获取的键名赋值给x,值赋值给y
  2. 第一个判断:当get获取的键名有flag且键名不等于flag时输出handsome,从逻辑判断这里永远为假,进不去。
  3. 第二个判断:当get没有获取到的flag参数且post没有获取到的flag参数时,输出is
  4. 第三个判断:当post获取到的flag参数是flag字符串或get获取到的flag参数是flag字符串时,输出is

第三步:获取flag

  1. 通过第一步获取到的源码最后一段发现要输出$flag这个变量才能显示flag
  2. 按f12查看源码发现卡在了第二判断,由于我们没有通过get或post传入flag参数
    在这里插入图片描述
  3. 如果我们传入flag=xx参数,foreach函数就会改变$flag的值,使最后一句不能正常输出flag的值
  4. 使用变量覆盖漏洞,不传入flag,但是将$yds的值修改为$flag,这样输出yds时,就会输出flag的值,构造payload:?yds=flag,在通过foreach($_GET as $x => $y){ $$x = $$y; }时,$x=yds,$y=flag;而$$x=$yds,$$y=$flag,这样$yds=$flag,输出yds时就会输出flag的值
  5. 思路二:传入flag参数且修改is参数,payload:?is=flag&flag=flag
    在这里插入图片描述
  相关解决方案