【反序列化】实现反序列化魔法函数自动调用计算器

反序列化字符串转换成对象

O:object

反序列化漏洞

以 __ 开头的函数,是PHP 中的魔术方法。

类中的魔术方法,在特定情况下会自动调用。即使魔术方法在类中没有被定义,也是真实存在的。

__construct() 在创建对象时自动调用

__destruct() 在销毁对象时自动调用

__wakeup() unserialize()时会自动调用这个函数

__sleep() serialize()时会自动调用这个函数

 代码运行原理


序列化:将类 TestClass 实例化为一个序列化的字符串

反序列化:解析从序列化字符串中恢复对象的函数(通过先将序列化字符串解码成字节流,然后再将其反序列化为对象的方式实现的。)

使用反序列化代码调取计算器

<?php
 
class TestClass {
    public function __wakeup() {
        system($_GET["cmd"]);
    }
}
//先序列化成字符串
$serializedData = serialize(new TestClass());
 
//反序列化(解析从序列化字符串中恢复对象的函数)
$object = unserialize($serializedData);
?>



调取计算机


?cmd=calc

当反序列化参数中包含 cmd 参数时,会调用 __wakeup 方法,该方法接收 cmd 参数并执行系统命令。这是因为系统函数 system 接收一个参数,并执行操作系统命令。所以,当序列化参数中包含 cmd 参数时,它会被用于 system 函数,并被执行

  • 7
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值