123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- --TEST--
- Bug #66356 (Heap Overflow Vulnerability in imagecrop())
- --EXTENSIONS--
- gd
- --FILE--
- <?php
- $img = imagecreatetruecolor(10, 10);
- // POC #1
- var_dump(imagecrop($img, array("x" => "a", "y" => 0, "width" => 10, "height" => 10)));
- $arr = array("x" => "a", "y" => "12b", "width" => 10, "height" => 10);
- var_dump(imagecrop($img, $arr));
- print_r($arr);
- // POC #2
- var_dump(imagecrop($img, array("x" => 0, "y" => 0, "width" => -1, "height" => 10)));
- // POC #3
- var_dump(imagecrop($img, array("x" => -20, "y" => -20, "width" => 10, "height" => 10)));
- // POC #4
- var_dump(imagecrop($img, array("x" => 0x7fffff00, "y" => 0, "width" => 10, "height" => 10)));
- // bug 66815
- var_dump(imagecrop($img, array("x" => 0, "y" => 0, "width" => 65535, "height" => 65535)));
- ?>
- --EXPECTF--
- object(GdImage)#2 (0) {
- }
- object(GdImage)#2 (0) {
- }
- Array
- (
- [x] => a
- [y] => 12b
- [width] => 10
- [height] => 10
- )
- Warning: imagecrop(): One parameter to a memory allocation multiplication is negative or zero, failing operation gracefully
- in %s on line %d
- bool(false)
- object(GdImage)#2 (0) {
- }
- object(GdImage)#2 (0) {
- }
- Warning: imagecrop(): Product of memory allocation multiplication would exceed INT_MAX, failing operation gracefully
- in %s on line %d
- bool(false)
|