PHP :: Bug #45392 :: ob_start()/ob_end_clean() and memory_limit
| Bug #45392 | ob_start()/ob_end_clean() and memory_limit | |||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Submitted: | 2008-06-29 22:30 UTC | Modified: | 2009-05-07 13:36 UTC |
|
||||||||||
| From: | flebron at bumeran dot com | Assigned: | iliaa (profile) | |||||||||||
| Status: | Closed | Package: | Output Control | |||||||||||
| PHP Version: | 5CVS-2008-11-01 | OS: | * | |||||||||||
| Private report: | No | CVE-ID: | None | |||||||||||
[2008-06-29 22:30 UTC] flebron at bumeran dot com
Description:
------------
When memory_limit is reached, and one is using the output buffering functions, instead of just dying with an "out of memory" error, the contents of the buffer are spilled onto stdout.
The output_buffering ini setting wasn't set to any particular limit.
Reproduce code:
---------------
<?php
ob_start();
$i = 0;
while($i++ < 10000000) {
echo str_repeat("lol", 42);
}
ob_end_clean();
/*Note that the 10,000,000 number varies according to your memory_limit*/
Expected result:
----------------
STDERR: Fatal error: Allowed memory size of 134217728 bytes exhausted at /home/flebron/cvs/php/php5.3-200806291230/main/output.c:395 (tried to allocate 133693441 bytes) in /home/flebron/cvs/php/ob.php on line 5
STDOUT: Nothing
Actual result:
--------------
STDERR: Fatal error: Allowed memory size of 134217728 bytes exhausted at /home/flebron/cvs/php/php5.3-200806291230/main/output.c:395 (tried to allocate 133693441 bytes) in /home/flebron/cvs/php/ob.php on line 5
STDOUT: The text in the buffer is printed to stdout (millions of "lolol"s).
Patches
Pull Requests
History
AllCommentsChangesGit/SVN commits
[2008-07-14 11:26 UTC] jani@php.net
This slightly modified script shows the bug without massive output: <?php ini_set('memory_limit', 100); ob_start(); $i = 0; while($i++ < 5000) { echo str_repeat("lol", 42); } ob_end_clean(); ?>[2008-09-17 00:20 UTC] iliaa@php.net
[2008-11-02 13:58 UTC] jani@php.net
[2008-12-01 20:45 UTC] iliaa@php.net
[2009-04-30 11:59 UTC] hwallenstone at gmx dot de
[2011-12-13 10:56 UTC] jakoch at web dot de
[2014-03-13 15:50 UTC] php at speed dot 1s dot fr
[2014-03-13 15:50 UTC] php at speed dot 1s dot fr