Réponses:
SI : vous n'avez besoin que d'un seul en-tête, au lieu de tous les en- têtes, la méthode la plus rapide est:
<?php
// Replace XXXXXX_XXXX with the name of the header you need in UPPERCASE (and with '-' replaced by '_')
$headerStringValue = $_SERVER['HTTP_XXXXXX_XXXX'];
ELSE IF : vous exécutez PHP en tant que module Apache ou, à partir de PHP 5.4, en utilisant FastCGI (méthode simple):
<?php
$headers = apache_request_headers();
foreach ($headers as $header => $value) {
echo "$header: $value <br />\n";
}
ELSE: Dans tous les autres cas, vous pouvez utiliser (implémentation de l'espace utilisateur):
<?php
function getRequestHeaders() {
$headers = array();
foreach($_SERVER as $key => $value) {
if (substr($key, 0, 5) <> 'HTTP_') {
continue;
}
$header = str_replace(' ', '-', ucwords(str_replace('_', ' ', strtolower(substr($key, 5)))));
$headers[$header] = $value;
}
return $headers;
}
$headers = getRequestHeaders();
foreach ($headers as $header => $value) {
echo "$header: $value <br />\n";
}
Voir aussi :
getallheaders () - (PHP> = 5.4) édition multiplateforme Alias de apache_request_headers()
apache_response_headers () - Récupère tous les en-têtes de réponse HTTP.
headers_list () - Récupère une liste des en-têtes à envoyer.
$_SERVER['HTTP_X_REQUESTED_WITH']
RFC3875 , 4.1.18:
Les méta-variables dont les noms commencent par
HTTP_
contiennent des valeurs lues dans les champs d'en-tête de demande client, si le protocole utilisé est HTTP. Le nom du champ d'en-tête HTTP est converti en majuscules, a toutes les occurrences de-
remplacé par_
et a étéHTTP_
ajouté au début pour donner le nom de la méta-variable.
$_SERVER
variable? La documentation PHP à php.net/manual/en/reserved.variables.server.php est évasive sur ce que nous pouvons être sûrs qu'il y aura.
cache-control
tête, mais je ne le vois nulle part $_SERVER
. Je vois plusieurs en-têtes préfixés HTTP_
, y compris "HTTP_ACCEPT" et "HTTP_UPGRADE_INSECURE_REQUESTS" et "HTTP_USER_AGENT" (parmi plusieurs autres). Mais rien pour "cache-control" rien pour "pragma". Ceci indépendamment de la casse ou du HTTP_
préfixe. Suis-je en train de manquer quelque chose?
_SERVER["HTTP_CACHE_CONTROL"] max-age=0
Vous devriez trouver tous les en-têtes HTTP dans la $_SERVER
variable globale préfixée avec HTTP_
majuscule et avec tirets (-) remplacés par des traits de soulignement (_).
Par exemple, vous X-Requested-With
pouvez le trouver dans:
$_SERVER['HTTP_X_REQUESTED_WITH']
Il peut être pratique de créer un tableau associatif à partir de la $_SERVER
variable. Cela peut être fait dans plusieurs styles, mais voici une fonction qui génère des clés en forme de chameau:
$headers = array();
foreach ($_SERVER as $key => $value) {
if (strpos($key, 'HTTP_') === 0) {
$headers[str_replace(' ', '', ucwords(str_replace('_', ' ', strtolower(substr($key, 5)))))] = $value;
}
}
Maintenant, utilisez simplement $headers['XRequestedWith']
pour récupérer l'en-tête souhaité.
Manuel PHP sur $_SERVER
: http://php.net/manual/en/reserved.variables.server.php
parseRequestHeaders()
fonction. Si un tel tableau associatif est nécessaire, alors IMO, la fonction apache est la meilleure option, car elle retourne exactement les en-têtes reçus au lieu d'une version CamelCase déformée. (Notez également qu'à partir de PHP 5.4, il n'est plus uniquement Apache.)
apache_request_headers()
ou getallheaders()
ne semble pas mettre en majuscule les noms d'en-tête lorsque j'ai testé. Ils reviennent exactement comme je passe du côté client. Alors pourquoi capitalisez-vous les noms d'en-tête dans une telle fonction de remplacement?
Depuis PHP 5.4.0, vous pouvez utiliser une getallheaders
fonction qui retourne tous les en-têtes de demande sous forme de tableau associatif:
var_dump(getallheaders());
// array(8) {
// ["Accept"]=>
// string(63) "text/html[...]"
// ["Accept-Charset"]=>
// string(31) "ISSO-8859-1[...]"
// ["Accept-Encoding"]=>
// string(17) "gzip,deflate,sdch"
// ["Accept-Language"]=>
// string(14) "en-US,en;q=0.8"
// ["Cache-Control"]=>
// string(9) "max-age=0"
// ["Connection"]=>
// string(10) "keep-alive"
// ["Host"]=>
// string(9) "localhost"
// ["User-Agent"]=>
// string(108) "Mozilla/5.0 (Windows NT 6.1; WOW64) [...]"
// }
Auparavant, cette fonction ne fonctionnait que lorsque PHP s'exécutait en tant que module Apache / NSAPI.
strtolower
fait défaut dans plusieurs des solutions proposées, la RFC2616 (HTTP / 1.1) définit les champs d'en-tête comme des entités insensibles à la casse. Le tout, pas seulement la partie valeur .
Par conséquent, des suggestions telles que l'analyse syntaxique des entrées HTTP_ sont fausses.
Mieux serait comme ça:
if (!function_exists('getallheaders')) {
foreach ($_SERVER as $name => $value) {
/* RFC2616 (HTTP/1.1) defines header fields as case-insensitive entities. */
if (strtolower(substr($name, 0, 5)) == 'http_') {
$headers[str_replace(' ', '-', ucwords(strtolower(str_replace('_', ' ', substr($name, 5)))))] = $value;
}
}
$this->request_headers = $headers;
} else {
$this->request_headers = getallheaders();
}
Notez les différences subtiles avec les suggestions précédentes. La fonction ici fonctionne également sur php-fpm (+ nginx).
Date
tête - et que "les valeurs des paramètres [texte dans Content-Type après le point-virgule] peuvent ou non être sensibles à la casse". Donc, étant donné qu'il existe au moins deux en-têtes avec des valeurs sensibles à la casse, il semble que vous vous trompiez.
HTTP header fields, which include general-header (section 4.5), request-header (section 5.3), response-header (section 6.2), and entity-header (section 7.1) fields, follow the same generic format as that given in Section 3.1 of RFC 822 [9]. Each header field consists of a name followed by a colon (":") and the field value. Field names are case-insensitive.
Je suppose donc que vous vous trompez.
Passez un nom d'en-tête à cette fonction pour obtenir sa valeur sans utiliser de for
boucle. Renvoie null si l'en-tête n'est pas trouvé.
/**
* @var string $headerName case insensitive header name
*
* @return string|null header value or null if not found
*/
function get_header($headerName)
{
$headers = getallheaders();
return isset($headerName) ? $headers[$headerName] : null;
}
Remarque: cela ne fonctionne qu'avec le serveur Apache, voir: http://php.net/manual/en/function.getallheaders.php
Remarque: cette fonction traitera et chargera tous les en-têtes dans la mémoire et elle est moins performante qu'une for
boucle.
Pour simplifier les choses, voici comment obtenir celle que vous souhaitez:
Facile:
$headerValue = $_SERVER['HTTP_X_REQUESTED_WITH'];
ou lorsque vous devez en obtenir un à la fois:
<?php
/**
* @param $pHeaderKey
* @return mixed
*/
function get_header( $pHeaderKey )
{
// Expanded for clarity.
$headerKey = str_replace('-', '_', $pHeaderKey);
$headerKey = strtoupper($headerKey);
$headerValue = NULL;
// Uncomment the if when you do not want to throw an undefined index error.
// I leave it out because I like my app to tell me when it can't find something I expect.
//if ( array_key_exists($headerKey, $_SERVER) ) {
$headerValue = $_SERVER[ $headerKey ];
//}
return $headerValue;
}
// X-Requested-With mainly used to identify Ajax requests. Most JavaScript frameworks
// send this header with value of XMLHttpRequest, so this will not always be present.
$header_x_requested_with = get_header( 'X-Requested-With' );
Les autres en-têtes sont également dans le tableau super global $ _SERVER, vous pouvez lire comment les obtenir ici: http://php.net/manual/en/reserved.variables.server.php
HTTP_
pas le$headerKey
J'utilisais CodeIgniter et j'ai utilisé le code ci-dessous pour l'obtenir. Peut être utile pour quelqu'un à l'avenir.
$this->input->get_request_header('X-Requested-With');
Voici comment je le fais. Vous devez obtenir tous les en-têtes si $ header_name n'est pas transmis:
<?php
function getHeaders($header_name=null)
{
$keys=array_keys($_SERVER);
if(is_null($header_name)) {
$headers=preg_grep("/^HTTP_(.*)/si", $keys);
} else {
$header_name_safe=str_replace("-", "_", strtoupper(preg_quote($header_name)));
$headers=preg_grep("/^HTTP_${header_name_safe}$/si", $keys);
}
foreach($headers as $header) {
if(is_null($header_name)){
$headervals[substr($header, 5)]=$_SERVER[$header];
} else {
return $_SERVER[$header];
}
}
return $headervals;
}
print_r(getHeaders());
echo "\n\n".getHeaders("Accept-Language");
?>
Cela me semble beaucoup plus simple que la plupart des exemples donnés dans d'autres réponses. Cela obtient également la méthode (GET / POST / etc.) Et l'URI demandés lors de l'obtention de tous les en-têtes, ce qui peut être utile si vous essayez de l'utiliser dans la journalisation.
Voici la sortie:
Array ( [HOST] => 127.0.0.1 [USER_AGENT] => Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:28.0) Gecko/20100101 Firefox/28.0 [ACCEPT] => text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 [ACCEPT_LANGUAGE] => en-US,en;q=0.5 [ACCEPT_ENCODING] => gzip, deflate [COOKIE] => PHPSESSID=MySessionCookieHere [CONNECTION] => keep-alive )
en-US,en;q=0.5
Voici un moyen simple de le faire.
// echo get_header('X-Requested-With');
function get_header($field) {
$headers = headers_list();
foreach ($headers as $header) {
list($key, $value) = preg_split('/:\s*/', $header);
if ($key == $field)
return $value;
}
}
Ce petit extrait PHP peut vous être utile:
<?php
foreach($_SERVER as $key => $value){
echo '$_SERVER["'.$key.'"] = '.$value."<br />";
}
?>
function getCustomHeaders()
{
$headers = array();
foreach($_SERVER as $key => $value)
{
if(preg_match("/^HTTP_X_/", $key))
$headers[$key] = $value;
}
return $headers;
}
J'utilise cette fonction pour obtenir les en-têtes personnalisés, si l'en-tête commence à partir de "HTTP_X_" nous poussons dans le tableau :)
si une seule clé est requise pour être récupérée, par exemple une "Host"
adresse est requise, alors nous pouvons utiliser
apache_request_headers()['Host']
Afin que nous puissions éviter les boucles et les mettre en ligne sur les sorties d'écho
Cela fonctionne si vous avez un serveur Apache
Code PHP:
$headers = apache_request_headers();
foreach ($headers as $header => $value) {
echo "$header: $value <br />\n";
}
Résultat:
Accept: */*
Accept-Language: en-us
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/4.0
Host: www.example.com
Connection: Keep-Alive