Unobstrusive debug output in PHP
Sometimes you want to echo out a value but you also know there's headers getting sent further down. Instead of screwing up the output:
header('X-Debug: '.$value);
...and inspect the result in Firebug's Net tab (or Chrome equivalent).
Written by Félix Saparelli
Related protips
8 Responses
How obvious, yet I never came up with that myself, neither have I read it anywhere else. I hate this "how come I didn't think of that before" feeling. Up-vote!
data:image/s3,"s3://crabby-images/d523d/d523d2166aa382503de171b3e81322c9d0f92e08" alt=""
Or use firePHP
data:image/s3,"s3://crabby-images/39595/39595fae90b7ae6d2ba0e7ced71c4c0b8f35bcd6" alt=""
Nice tip =)
data:image/s3,"s3://crabby-images/8a970/8a9702ceb6cb5e9e2b9dcb7d34b51c59591b2b10" alt=""
Packfire has a debugger that uses Firebug output.
data:image/s3,"s3://crabby-images/09541/09541a779bc2bc3f1f86996a8b1737020850800e" alt=""
You could also log to syslog, which is standard of logging for quite a while... Windows has a similar solution.
Headers shouldn't be messed with. Firebug is known for causing problems due to the large header sizes. Besides that, is using "X-" for headers deprecated behaviour, see: http://www.ietf.org/rfc/rfc6648.txt
data:image/s3,"s3://crabby-images/e3e28/e3e281ff82b3f74537f58c0ca92fefa1a9b0d9f2" alt=""
I like using Chrome PHP http://www.chromephp.com my only issue with the header() is that you must call if before you generate any output.
I love using xdbug with PHPstorm as well
data:image/s3,"s3://crabby-images/d1836/d18364bab88f874634ece6f76de9a206bb8703f2" alt=""
Also:
if (isset($_GET['debug']) && $_GET['debug'] == 'true')
{
header('X-Debug: '.$value);
}
To control whether or not the header gets sent. (Performance Optimization?)
data:image/s3,"s3://crabby-images/41b79/41b7966bab01c8ca859046afa6bc3d98228424ae" alt=""
@matthewbj The performance optimisation is to not use it at all when not doing debugging. This trick is the equivalent of peppering console.log calls in JS: it's highly inefficient but very useful when doing quick checks. If you want a long-term debug log solution, look into proper logging (to file or tty or socket) so you don't mix things in the output.