bug70168.phpt 634 B

12345678910111213141516171819202122232425262728293031323334
  1. --TEST--
  2. SPL: Bug #70168 Use After Free Vulnerability in unserialize() with SplObjectStorage
  3. --FILE--
  4. <?php
  5. $inner = 'x:i:1;O:8:"stdClass":0:{};m:a:0:{}';
  6. $exploit = 'a:2:{i:0;C:16:"SplObjectStorage":'.strlen($inner).':{'.$inner.'}i:1;R:3;}';
  7. $data = unserialize($exploit);
  8. for($i = 0; $i < 5; $i++) {
  9. $v[$i] = 'hi'.$i;
  10. }
  11. var_dump($data);
  12. ?>
  13. --EXPECTF--
  14. array(2) {
  15. [0]=>
  16. object(SplObjectStorage)#%d (1) {
  17. ["storage":"SplObjectStorage":private]=>
  18. array(1) {
  19. [0]=>
  20. array(2) {
  21. ["obj"]=>
  22. object(stdClass)#2 (0) {
  23. }
  24. ["inf"]=>
  25. NULL
  26. }
  27. }
  28. }
  29. [1]=>
  30. int(1)
  31. }