|
php.net | support | documentation | report a bug | advanced search | search howto | statistics | random bug | login |
PatchesPull RequestsHistoryAllCommentsChangesGit/SVN commits
[2003-04-15 06:05 UTC] edink@php.net
[2003-04-15 09:28 UTC] nospam at 1111-internet dot com
[2003-04-15 20:10 UTC] iliaa@php.net
[2011-01-01 20:39 UTC] jani@php.net
-Summary: anomaly re: zlib.output_compression
and header("Location:...
+Summary: Allow controlling header flushing
with output buffering
-Package: Feature/Change Request
+Package: Zlib related
-Operating System: FreeBSD 4.8
+Operating System: *
-PHP Version: 4.3.1
+PHP Version: *
[2013-08-01 12:26 UTC] mike@php.net
-Status: Open
+Status: Wont fix
-Assigned To:
+Assigned To: mike
|
|||||||||||||||||||||||||||
Copyright © 2001-2025 The PHP GroupAll rights reserved. |
Last updated: Fri Oct 24 22:00:02 2025 UTC |
Consider the following code: <?php echo str_repeat("x", 4095); header("Location: /somewhere_else.php"); exit; ?> If zlib.output_compression is off, this will cause 4095 "x"s to display, properly followed by an error on the header line. If zlib.output_compression is on, however, the echo line will execute - but nothing is output immediately because it fails to fill the compression buffer - so the header line goes ahead and executes and redirects successfully, completely spurning the output. Granted, nobody would use this particular example in a real world application - I just set it up to illustrate the problem. I have run into real situations, though, where I'm doing diagnostics or inadvertently cause an error on code lines that logically precede a header("Location:... call. This problem prevents my diagnistic or error messages from showing up. Consider: <?php // set up mysql connection and mysql_query("insert into mytable (myfield) values (". $_GET["myvalue"]. ")"); // no problem if $_GET["myvalue"] is a number, // but if it's a non-numeric string like "abc" that line will generate an error message // which I would like to see so I can fix the problem... // but the error message doesn't fill the compression buffer // so the following redirect happens and usurps the error message header("Location: /somewhere_else.php"); exit; // so I go on as though there was never a problem // until I look at my still-empty database table some time later... ?>