bug70166.phpt 483 B

123456789101112131415161718192021222324252627
  1. --TEST--
  2. SPL: Bug #70166 Use After Free Vulnerability in unserialize() with SPLArrayObject
  3. --FILE--
  4. <?php
  5. $inner = 'x:i:1;a:0:{};m:a:0:{}';
  6. $exploit = 'a:2:{i:0;C:11:"ArrayObject":'.strlen($inner).':{'.$inner.'}i:1;R:5;}';
  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(ArrayObject)#%d (1) {
  17. ["storage":"ArrayObject":private]=>
  18. array(0) {
  19. }
  20. }
  21. [1]=>
  22. array(0) {
  23. }
  24. }