header
(PHP 4, PHP 5)
header — Envoie un en-tête HTTP
Description
$string
[, bool $replace
= true
[, int $http_response_code
]] )
header() permet de spécifier l'en-tête HTTP
string
lors de l'envoi des fichiers HTML.
Reportez-vous à » HTTP/1.1
Specification pour plus d'informations sur les en-têtes
HTTP.
N'oubliez jamais que header() doit être appelée avant que le moindre contenu ne soit envoyé, soit par des lignes HTML habituelles dans le fichier, soit par des affichages PHP. Une erreur très classique est de lire un fichier avec include ou require, et de laisser des espaces ou des lignes vides, qui produiront un affichage avant que la fonction header() ne soit appelée. Le même problème existe avec les fichiers PHP/HTML standards.
<html>
<?php
/* Ceci produira une erreur. Notez la sortie ci-dessus,
* qui se trouve avant l'appel à la fonction header() */
header('Location: http://www.example.com/');
exit;
?>
Liste de paramètres
-
string
-
L'en-tête.
Il y a deux en-têtes spéciaux. Le premier commence par la chaîne "HTTP/" (insensible à la casse), qui est utilisée pour signifier le statut HTTP à envoyer. Par exemple, si vous avez configuré Apache pour utiliser les scripts PHP pour gérer les requêtes vers des fichiers inexistants (en utilisant la directive ErrorDocument), vous voulez-vous assurer que le script génère un code statut correct.
<?php header("HTTP/1.0 404 Not Found"); ?>
Le deuxième type d'appel spécial est "Location:". Non seulement il renvoie un en-tête au client, mais, en plus, il envoie un statut REDIRECT (302) au navigateur tant qu'un code statut 201 ou 3xx n'a pas été envoyé.
<?php header("Location: http://www.example.com/"); /* Redirection du navigateur */ /* Assurez-vous que la suite du code ne soit pas exécutée une fois la redirection effectuée. */ exit; ?>
-
replace
-
Le paramètre optionnel
replace
indique si la fonction header() doit remplacer un en-tête précédemment émis, ou bien ajouter un autre en-tête du même type. Par défaut, un nouvel en-tête va écraser le précédent, mais si vous passezFALSE
dans cet argument, vous pouvez forcer les en-têtes multiples pour un même type d'en-tête. Par exemple :<?php header('WWW-Authenticate: Negotiate'); header('WWW-Authenticate: NTLM', false); ?>
-
http_response_code
-
Force le code réponse HTTP à la valeur spécifiée.
Valeurs de retour
Aucune valeur n'est retournée.
Historique
Version | Description |
---|---|
4.4.2 et 5.1.2 | Cette fonction prévient l'envoi de plus d'un en-tête en même temps pour lutter contre les attaques par injection d'en-tête. |
4.3.0 |
Ajout du paramètre http_response_code .
|
4.0.4 |
Ajout du paramètre replace .
|
Exemples
Exemple #1 Boîte de téléchargement
Exemple #2 Directives concernant la mise en cache
<?php
header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1
header("Expires: Sat, 26 Jul 1997 05:00:00 GMT"); // Date dans le passé
?>
Note:
L'ID de session n'est pas passé avec l'en-tête Location même si session.use_trans_sid est activé. Il doit être passé manuellement en utilisant la constante
SID
.
Voir aussi
- headers_sent() - Indique si les en-têtes HTTP ont déjà été envoyés
- setcookie() - Envoie un cookie
- http_response_code() - Récupère ou change le code de la réponse HTTP
- La section sur l'identification HTTP