攻防世界--unseping(反序列化)

本文介绍了在攻防世界中遇到的一个反序列化问题,通过代码审计发现可以通过命令执行来获取敏感信息。首先尝试了ifconfig命令,但因系统环境不同而未成功,改为使用ls命令。由于ls在黑名单中,作者通过各种命令执行绕过方式,如/反斜杠、${IFS}、八进制转换等,成功查看到目录中的flag文件,并最终找到了获取flag内容的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<?php
highlight_file(__FILE__);

class ease{
    
    private $method;//私有变量
    private $args;
    function __construct($method, $args) {//创建对象
        $this->method = $method;  //赋值
        $this->args = $args;
    }
 
    function __destruct(){  //析构函数,当对象的引用都被删除或对象都没被引用时执行
        if (in_array($this->method, array("ping"))) {//判断method是否为ping
            call_user_func_array(array($this, $this->method), $this->args);//ping命令
        }
    } 
 
    function ping($ip){//执行ping
        exec($ip, $result);//返回结果和类型
        var_dump($result);
    }

    function waf($str){
        if (!preg_match_all("/(\||&|;| |\/|cat|flag|tac|php|ls)/", $str, $pat_array)) {//黑名单过滤
            return $str;
        } else {
            echo "don't hack";
        }
    }
 
    function __wakeup(){  //序列化后调用
        foreach($this->args as $k => $v) {//数组遍历
            $this->args[$k] = $this-&
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值