PHP代码,实现反序列化的时候魔法函数执行系统命令

使用PHP代码,实现反序列化的时候魔法函数执行系统命令

序列化:serialize 将对象格式化成有序的字符串

反序列化:unserialize 将字符串还原成原来的对象

漏洞成因

序列化和反序列化本身不存在漏洞,之所以会有反序列化漏洞,是由于开发者在编写序列化代码的时候加入了恶意代码

序列化和反序列化本身是为了实现数据在网络上完整高效的传输,但是由于反序列化过程中,对象的魔术方法会自动调用,魔术方法本身调用了别的方法,最终呈现一种链式调用,直到执行任意的代码或者命令。

php序列化与反序列化魔术方法

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

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

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

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

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

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

反序列化漏洞执行系统命令

简单的命令执行

<?php
class clothing{
	public $color;
	public $size;
	
	public function __wakeup(){
	$cmd=$_GET['cmd'];
    @system($cmd);
	}
	
}

$cl1=new clothing;

$cl1->color="red";
$cl1->size=36;

//var_dump($an1);
$cl2 = serialize($cl1);
@unserialize($cl2);


?>
  1. 执行ipconfig命令
    在这里插入图片描述
    2.弹出计算器
    在这里插入图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值