headers_sent
(PHP 4, PHP 5, PHP 7)
headers_sent — Checks if or where headers have been sent
Description
&$file
[, int &$line
]] )Checks if or where headers have been sent.
You can't add any more header lines using the header() function once the header block has already been sent. Using this function you can at least prevent getting HTTP header related error messages. Another option is to use Output Buffering.
Parameters
-
file
-
If the optional
file
andline
parameters are set, headers_sent() will put the PHP source file name and line number where output started in thefile
andline
variables. -
line
-
The line number where the output started.
Return Values
headers_sent() will return FALSE
if no HTTP headers
have already been sent or TRUE
otherwise.
Examples
Example #1 Examples using headers_sent()
<?php
// If no headers are sent, send one
if (!headers_sent()) {
header('Location: http://www.example.com/');
exit;
}
// An example using the optional file and line parameters
// Note that $filename and $linenum are passed in for later use.
// Do not assign them values beforehand.
if (!headers_sent($filename, $linenum)) {
header('Location: http://www.example.com/');
exit;
// You would most likely trigger an error here.
} else {
echo "Headers already sent in $filename on line $linenum\n" .
"Cannot redirect, for now please click this <a " .
"href=\"http://www.example.com\">link</a> instead\n";
exit;
}
?>
See Also
- ob_start() - Turn on output buffering
- trigger_error() - Generates a user-level error/warning/notice message
- headers_list() - Returns a list of response headers sent (or ready to send)
- header() - Send a raw HTTP header for a more detailed discussion of the matters involved.
Version en cache
05/01/2025 17:38:50 Cette version de la page est en cache (à la date du 05/01/2025 17:38:50) afin d'accélérer le traitement. Vous pouvez activer le mode utilisateur dans le menu en haut pour afficher la dernère version de la page.Document créé le 30/01/2003, dernière modification le 26/10/2018
Source du document imprimé : https://www.gaudry.be/php-rf-headers-sent.html
L'infobrol est un site personnel dont le contenu n'engage que moi. Le texte est mis à disposition sous licence CreativeCommons(BY-NC-SA). Plus d'info sur les conditions d'utilisation et sur l'auteur.
Références
Ces références et liens indiquent des documents consultés lors de la rédaction de cette page, ou qui peuvent apporter un complément d'information, mais les auteurs de ces sources ne peuvent être tenus responsables du contenu de cette page.
L'auteur de ce site est seul responsable de la manière dont sont présentés ici les différents concepts, et des libertés qui sont prises avec les ouvrages de référence. N'oubliez pas que vous devez croiser les informations de sources multiples afin de diminuer les risques d'erreurs.