PHP序列化与反序列化

Posted Ch0bits

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PHP序列化与反序列化相关的知识,希望对你有一定的参考价值。

题目(攻防世界):

__construct和__destruct的魔术方法是默认执行的,我们可以忽视他们,__wake up执行以后会返回当前主页上,需要绕过,下面的正则匹配preg_match也需要绕过,flag在f14g.php

绕过之后就需要传个var的值,值为base64编码以后的序列化


 

__wakeup()魔术方法

unserialize() 会检查是否存在一个 __wakeup() 方法。如果存在,则会先调用 __wakeup 方法,预先准备对象需要的资源。 

__wakeup 百度一下  发现这是一个CVE漏洞 ==》当成员属性数目大于实际数目时可绕过wakeup方法(CVE-2016-7124)

 

正则匹配的话在对象长度之前添加一个+号可以绕过

 

先运行代码,返回序列化之后的内容

 

这里我们其实发现了问题,参数名Demofile的长度为10,可是双引号里面只有8个字符,剩下两个跑哪去了?

于是我又拿到在线编译器去编译:

发现空格存在

不过即使你把空格加上了,最后出来的编码也是错的,我用phpstorm和base64在线编码都试过(我找了很久也没有发现问题在哪里)

按照上面说的绕过,然后拿去编码(错误范本):

比较大佬的代码(下一行):

就是那两个字符出的问题

不管拿去url里面get传参,得到flag

以上是关于PHP序列化与反序列化的主要内容,如果未能解决你的问题,请参考以下文章

php 序列化与反序列化

PHP序列化与反序列化学习

PHP序列化与反序列化学习

php序列化与反序列化

PHP 序列化与反序列化函数

php序列化与反序列化