MajAfy
MajAfy

Reputation: 3097

header() error not shown in php

I wrote a PHP program, I use session_start() and header() functions, I know I should use this functions before I sending anything to client. it's ok, but for test I send a test message to client with echo "test"; before using header(), but I didn't get any error and header function work without any problem !

In previous versions of PHP at this time I will got a message like :

Warning: Cannot modify header information - headers already sent by (output started at /some/file.php:22) in /some/file.php on line 60

I wan't to know why I didn't get any error message ?!

My php version is 5.3.1 and error_reporting is on E_ALL

Upvotes: 0

Views: 468

Answers (3)

MajAfy
MajAfy

Reputation: 3097

I found the problem, I don't use any FrameWork.

the problem was error_reporting('E_ALL');

I wrote this code on first of my program, and so PHP didn't return any errors ! I deleted this line and I get the errors !

This is kidding because this line said to PHP to show ALL errors ! I don't know why PHP don't show any errors.

Upvotes: 0

Michel Feldheim
Michel Feldheim

Reputation: 18250

This might be possible because you write into an output buffer (ob_start) which doesn't actually return anything to the client until you explicitly flush the buffer (ob_flush or ob_end_*) or the script ends.

The fact that you can't send headers after you begun writing the body part of your HTTP response is not a php but a HTTP protocol limitation, so this cannot be version specific either.

Many frameworks like the Zend Framework use output buffers so a developer doesn't need to care about the order.

Upvotes: 0

Alex
Alex

Reputation: 12079

You don't see the error because
a. output buffering is on
b. the server ignores your error_reporting function because something else instructs it otherwise run phpinfo(); and see what it says there about output buffering and about error_reporting.

Upvotes: 1

Related Questions