(PHP 5, PHP 7, PHP 8)
get_headers — Retourne tous les en-têtes envoyés par le serveur en réponse à une requête HTTP
$url
, bool $associative
= false
, ?resource $context
= null
): array|falseget_headers() retourne un tableau avec les en-têtes envoyés par le serveur en réponse à une requête HTTP.
url
L'URL cible.
associative
Si le paramètre optionnel associative
est défini à true
,
get_headers() analyse la réponse et définit les index du tableau.
context
Un contexte de ressource valide créé avec
stream_context_create(), ou null
pour utiliser le contexte par défaut.
Retourne un tableau indexé ou associatif contenant les en-têtes, ou false
si une erreur survient.
Version | Description |
---|---|
8.0.0 |
associative a été changé de int en bool.
|
7.1.0 |
Le paramètre context a été ajouté.
|
Exemple #1 Exemple avec get_headers()
<?php
$url = 'http://www.example.com';
print_r(get_headers($url));
print_r(get_headers($url, true));
?>
Résultat de l'exemple ci-dessus est similaire à :
Array ( [0] => HTTP/1.1 200 OK [1] => Date: Sat, 29 May 2004 12:28:13 GMT [2] => Server: Apache/1.3.27 (Unix) (Red-Hat/Linux) [3] => Last-Modified: Wed, 08 Jan 2003 23:11:55 GMT [4] => ETag: "3f80f-1b6-3e1cb03b" [5] => Accept-Ranges: bytes [6] => Content-Length: 438 [7] => Connection: close [8] => Content-Type: text/html ) Array ( [0] => HTTP/1.1 200 OK [Date] => Sat, 29 May 2004 12:28:14 GMT [Server] => Apache/1.3.27 (Unix) (Red-Hat/Linux) [Last-Modified] => Wed, 08 Jan 2003 23:11:55 GMT [ETag] => "3f80f-1b6-3e1cb03b" [Accept-Ranges] => bytes [Content-Length] => 438 [Connection] => close [Content-Type] => text/html )
Exemple #2 Exemple avec get_headers() en utilisant HEAD
<?php
// Par défaut, get_headers utilise une requête GET pour récupérer les
// en-têtes. Si vous voulez plutôt envoyer une requête HEAD, vous pouvez le
// faire en utilisant un contexte de flux :
stream_context_set_default(
array(
'http' => array(
'method' => 'HEAD'
)
)
);
$headers = get_headers('http://example.com');
?>