Maison >développement back-end >tutoriel php >Utilisation détaillée de $_SERVER en PHP

Utilisation détaillée de $_SERVER en PHP

不言
不言original
2018-04-04 10:12:2715599parcourir

Le contenu de cet article est l'utilisation détaillée de $_SERVER en PHP. Maintenant, je le partage avec tout le monde et je peux également donner une référence aux amis dans le besoin

$_SERVER['PHP_SELF'] #Actuellement fonctionnel Le nom de fichier du script exécuté, lié à la racine du document.
$_SERVER['argv'] #Paramètres passés au script.
$_SERVER['argc'] #Contient le nombre d'arguments de ligne de commande transmis au programme (s'il est exécuté en mode ligne de commande).
$_SERVER['GATEWAY_INTERFACE'] #La version de la spécification CGI utilisée par le serveur. Par exemple, "CGI/1.1".
$_SERVER['SERVER_NAME'] #Le nom de l'hôte du serveur sur lequel le script est actuellement en cours d'exécution.
$_SERVER['SERVER_SOFTWARE'] #La chaîne d'identification du serveur, donnée dans l'en-tête lors de la réponse à la requête.
$_SERVER['SERVER_PROTOCOL'] #Le nom et la version du protocole de communication lors de la demande de la page. Par exemple, « HTTP/1.0 ».
$_SERVER['REQUEST_METHOD'] #Méthode de requête lors de l'accès à la page. Par exemple : "GET", "HEAD", "POST", "PUT".
$_SERVER['QUERY_STRING'] #Chaîne de requête.
$_SERVER['DOCUMENT_ROOT'] #Le répertoire racine du document où se trouve le script en cours d'exécution. Défini dans le fichier de configuration du serveur.
$_SERVER['HTTP_ACCEPT'] #Contenu de l'entête Accept: de la requête en cours.
$_SERVER['HTTP_ACCEPT_CHARSET'] #Contenu du Accept-Charset : en-tête de la requête en cours. Par exemple : "iso-8859-1,*,utf-8".
$_SERVER['HTTP_ACCEPT_ENCODING'] #Contenu de l'entête Accept-Encoding: de la requête en cours. Par exemple : "gzip".
$_SERVER['HTTP_ACCEPT_LANGUAGE']#Contenu de l'en-tête Accept-Language : de la requête en cours. Par exemple : "fr".
$_SERVER['HTTP_CONNECTION'] #Contenu de la Connexion : entête de la requête en cours. Par exemple : « Keep-Alive ».
$_SERVER['HTTP_HOST'] #Le contenu de l'en-tête Host: de la requête en cours.
$_SERVER['HTTP_REFERER'] #L'adresse URL de la page précédente liée à la page actuelle.
$_SERVER['HTTP_USER_AGENT'] #Contenu du User_Agent : entête de la requête en cours.
$_SERVER['HTTPS'] — S'il est accessible via https, il est défini sur une valeur non vide (on), sinon il renvoie off
$_SERVER['REMOTE_ADDR'] #L'adresse IP de l'utilisateur qui parcourt l'adresse de la page actuelle.
$_SERVER['REMOTE_HOST'] #Le nom d'hôte de l'utilisateur qui parcourt la page actuelle.
$_SERVER['REMOTE_PORT'] #Le port utilisé par les utilisateurs pour se connecter au serveur.
$_SERVER['SCRIPT_FILENAME'] #Le nom de chemin absolu du script en cours d'exécution.
$_SERVER['SERVER_ADMIN'] #Informations sur l'administrateur
$_SERVER['SERVER_PORT'] #Port utilisé par le serveur
$_SERVER['SERVER_SIGNATURE'] #Contient des caractères pour la version du serveur et le nom d'hôte virtuel chaîne.
$_SERVER['PATH_TRANSLATED'] #Le chemin de base du système de fichiers (pas le répertoire racine du document) où se trouve le script actuel.
$_SERVER['SCRIPT_NAME'] #Contient le chemin du script actuel. Ceci est utile lorsque la page doit pointer vers elle-même.
$_SERVER['REQUEST_URI'] #L'URI requis pour accéder à cette page. Par exemple, "/index.html".
$_SERVER['PHP_AUTH_USER'] #Lorsque PHP s'exécute en mode module Apache et utilise la fonction d'authentification HTTP, cette variable est le nom d'utilisateur saisi par l'utilisateur.
$_SERVER['PHP_AUTH_PW'] #Lorsque PHP s'exécute en mode module Apache et utilise la fonction d'authentification HTTP, cette variable est le mot de passe saisi par l'utilisateur.
$_SERVER['AUTH_TYPE'] #Lorsque PHP s'exécute en mode module Apache et utilise la fonction d'authentification HTTP, cette variable est le type d'authentification.
$_SERVER["HTTP_X_FORWARDED_FOR"] #Obtenir la véritable adresse IP du client via le serveur proxy
$_SERVER['HTTP_VIA'] #IP du serveur proxy
$_SERVER['HTTP_CLIENT_IP'] #IP du client

Variable du serveur : $_SERVER

Remarque : dans PHP 4.1.0 et les versions ultérieures, utilisez . Les versions précédentes utilisaient $HTTP_SERVER_VARS.

$_SERVER est un tableau contenant des éléments tels que des en-têtes, des chemins et des emplacements de script. Les entités du tableau sont créées par le serveur web. Il n'y a aucune garantie que tous les serveurs produiront tous les messages ; les serveurs peuvent ignorer certains messages ou générer de nouveaux messages non répertoriés ci-dessous. Cela signifie qu'un grand nombre de ces variables sont spécifiées dans la spécification CGI 1.1, vous devez donc l'étudier attentivement.

Il s'agit d'une "superglobale", ou peut être décrite comme une variable globale automatique. Cela signifie simplement que cela fonctionne dans tous les scripts. Vous n'avez pas besoin d'utiliser global $_SERVER pour y accéder dans une fonction ou une méthode, comme vous le feriez avec $HTTP_SERVER_VARS.

$HTTP_SERVER_VARS contient les mêmes informations, mais n'est pas une variable globale automatique. (Remarque : $HTTP_SERVER_VARS et $_SERVER sont des variables différentes et PHP les gère différemment.)

Ces variables sont également disponibles dans tous les scripts si la directive register_globals est définie ; séparé les tableaux $_SERVER et $HTTP_SERVER_VARS. Pour obtenir des informations connexes, consultez le chapitre relatif à la sécurité Utilisation de Register Globals. Ces variables globales individuelles ne sont pas des variables globales automatiques.

Vous constaterez peut-être que certains des éléments $_SERVER répertoriés ci-dessous ne sont pas disponibles. Notez que peu des éléments répertoriés ci-dessous sont valides (ou n'ont aucune signification réelle) si vous exécutez PHP à partir de la ligne de commande.

"PHP_SELF"
Le nom de fichier du script en cours d'exécution, lié à la racine du document. Par exemple, utiliser $_SERVER['PHP_SELF'] dans un script avec l'adresse URL
http://easyboor.com/test.php/foo.bar entraînera / Le résultat de test.php/foo.bar.

Cette variable n'a aucun effet si PHP est exécuté depuis la ligne de commande.

"argv"
L'argument passé à ce script. Lorsque le script est exécuté en mode ligne de commande, la variable argv est transmise au programme sous forme d'arguments de ligne de commande de style C. Lorsque la méthode GET est appelée, cette variable contient les données demandées.

"argc"
Contient le nombre d'arguments de ligne de commande transmis au programme (s'il est exécuté en mode ligne de commande).

"GATEWAY_INTERFACE"
La version de la spécification CGI utilisée par le serveur. Par exemple, "CGI/1.1".

'SERVER_NAME'
Le nom de l'hôte du serveur sur lequel le script est actuellement en cours d'exécution. Si le script s'exécute sur un hôte virtuel, le nom est déterminé par la valeur définie pour cet hôte virtuel.

'SERVER_SOFTWARE'
La chaîne identifiant le serveur, donnée dans l'en-tête lors de la réponse à la requête.

"SERVER_PROTOCOL"
Le nom et la version du protocole de communication lors de la demande de la page. Par exemple, « HTTP/1.0 ».

"REQUEST_METHOD"
La méthode de requête lors de l'accès à la page. Par exemple : "GET", "HEAD", "POST", "PUT".

«QUERY_STRING»
La chaîne de requête.

"DOCUMENT_ROOT"
Le répertoire racine du document où se trouve le script en cours d'exécution. Défini dans le fichier de configuration du serveur.

"HTTP_ACCEPT"
Contenu de l'Accept : en-tête de la requête en cours.

"HTTP_ACCEPT_CHARSET"
Contenu du Accept-Charset : en-tête de la requête en cours. Par exemple : "iso-8859-1,*,utf-8".

"HTTP_ACCEPT_ENCODING"
Contenu de l'Accept-Encoding : en-tête de la requête en cours. Par exemple : "gzip".

"HTTP_ACCEPT_LANGUAGE"
Contenu de l'Accept-Language : en-tête de la requête en cours. Par exemple : "fr".

« HTTP_CONNECTION »
Contenu de la Connexion : entête de la requête en cours. Par exemple : « Keep-Alive ».

« HTTP_HOST »
Contenu de l'Hôte : entête de la requête en cours.

"HTTP_REFERER"
L'adresse URL de la page précédente qui renvoie à la page actuelle. Tous les agents utilisateurs (navigateurs) ne définiront pas cette variable, et certains peuvent également modifier HTTP_REFERER manuellement. Cette variable n’est donc pas toujours vraie.

"HTTP_USER_AGENT"
Contenu du User_Agent : entête de la requête en cours. Cette chaîne indique des informations sur l'agent utilisateur accédant à cette page. Un exemple typique est : Mozilla/4.5 [en] (X11 ; U ; Linux 2.2.9 i586). Vous pouvez également utiliser get_browser() pour obtenir ces informations.

"REMOTE_ADDR"
L'adresse IP de l'utilisateur qui parcourt la page actuelle.

'REMOTE_HOST'
Le nom d'hôte de l'utilisateur qui parcourt la page actuelle. La résolution inversée du nom de domaine est basée sur le REMOTE_ADDR de l'utilisateur.

Remarque : Le serveur Web doit être configuré pour créer cette variable. Par exemple, Apache nécessite HostnameLookups On dans httpd.conf. Voir gethostbyaddr().

"REMOTE_PORT"
Le port utilisé par les utilisateurs pour se connecter au serveur.

"SCRIPT_FILENAME"
Le chemin absolu du script en cours d'exécution.

"SERVER_ADMIN"
Cette valeur spécifie le paramètre SERVER_ADMIN dans le fichier de configuration du serveur Apache. Si le script s'exécute sur un hôte virtuel, cette valeur est celle de cet hôte virtuel.

"SERVER_PORT"
Le port utilisé par le serveur. La valeur par défaut est "80". Si vous utilisez une connexion sécurisée SSL, cette valeur correspond au port HTTP que vous avez défini.

"SERVER_SIGNATURE"
Une chaîne contenant la version du serveur et le nom d'hôte virtuel.

"PATH_TRANSLATED"
Le chemin de base du système de fichiers (et non la racine du document) où se trouve le script actuel. C'est le résultat une fois que le serveur a été imagé d'un chemin virtuel vers un chemin réel.

"SCRIPT_NAME"
Contient le chemin d'accès au script actuel. Ceci est utile lorsque la page doit pointer vers elle-même.

"REQUEST_URI"
L'URI requis pour accéder à cette page. Par exemple, "/index.html".

"PHP_AUTH_USER"
Lorsque PHP s'exécute en mode module Apache et que la fonction d'authentification HTTP est utilisée, cette variable est le nom d'utilisateur saisi par l'utilisateur.

"PHP_AUTH_PW"
Lorsque PHP s'exécute en mode module Apache et que la fonction d'authentification HTTP est utilisée, cette variable est le mot de passe saisi par l'utilisateur.

"AUTH_TYPE"
Lorsque PHP s'exécute en mode module Apache et que l'authentification HTTP est utilisée, cette variable est le type d'authentification.

Recommandations associées :

Partage récapitulatif de l'utilisation de $_SERVER en PHP

Détails sur $_SERVER en PHP

Analyse de la fonction $_SERVER en PHP


Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn