Heim > Backend-Entwicklung > PHP-Problem > Bringen Sie Ihnen bei, wie man $_SERVER spielt

Bringen Sie Ihnen bei, wie man $_SERVER spielt

醉折花枝作酒筹
Freigeben: 2023-03-11 21:06:01
Original
2240 Leute haben es durchsucht

Im vorherigen Artikel haben wir erfahren, was superglobale Variablen sind und was $GLOBALS ist. Wenn Sie es brauchen, lesen Sie bitte „Der Editor bringt Ihnen $GLOBALS in Variablen in PHP bei.“ Dieses Mal stellen wir Ihnen $_SERVER vor, Sie können bei Bedarf darauf verweisen.

Damit wir diese Anordnung verstehen, schauen wir uns eine kleine Kastanie an.

<?php 
echo $_SERVER[&#39;PHP_SELF&#39;];
echo "<br>";
echo $_SERVER[&#39;SERVER_NAME&#39;];
echo "<br>";
echo $_SERVER[&#39;HTTP_HOST&#39;];
echo "<br>";
echo $_SERVER[&#39;HTTP_REFERER&#39;];
echo "<br>";
echo $_SERVER[&#39;HTTP_USER_AGENT&#39;];
echo "<br>";
echo $_SERVER[&#39;SCRIPT_NAME&#39;];
?>
Nach dem Login kopieren

Lassen Sie uns zunächst einen groben Blick auf die Ergebnisse werfen. Es scheint, dass es sich bei allen um dieselbe Adresse handelt. Dann können wir mutig vermuten, dass es sich bei diesem Array um ein Array handelt, das Informationen speichert.

$_SERVER ist ein Array, das Header-Informationen (Header), Pfad (Pfad) und Skriptspeicherorte (Skriptspeicherorte) sowie andere Informationen enthält. Die Elemente in diesem Array werden vom Webserver erstellt. Es gibt keine Garantie dafür, dass jeder Server alle Artikel bereitstellt; Server ignorieren möglicherweise einige Artikel oder servieren Artikel, die hier nicht aufgeführt sind.

Lassen Sie uns über die wichtigen Elemente in allen $_SERVER-Variablen sprechen.

$_SERVER['PHP_SELF'], der Dateiname des aktuell ausgeführten Skripts, bezogen auf das Dokumentstammverzeichnis. Beispielsweise führt die Verwendung von $_SERVER['PHP_SELF'] in einem Skript unter http://example.com/test.php/foo.bar zu /test.php/foo.bar. Die Konstante __FILE__ enthält den vollständigen Pfad und Dateinamen der aktuellen (d. h. enthaltenden) Datei. Ab PHP-Version 4.3.0 enthält diese Variable den Skriptnamen, wenn PHP im Befehlszeilenmodus ausgeführt wird. Diese Variable ist in früheren Versionen nicht verfügbar.
  • $_SERVER['GATEWAY_INTERFACE'], die vom Server verwendete Version der CGI-Spezifikation; zum Beispiel „CGI/1.1“. http://example.com/test.php/foo.bar 的脚本中使用 $_SERVER['PHP_SELF'] 将得到 /test.php/foo.bar。__FILE__ 常量包含当前(例如包含)文件的完整路径和文件名。 从 PHP 4.3.0 版本开始,如果 PHP 以命令行模式运行,这个变量将包含脚本名。之前的版本该变量不可用。

  • $_SERVER['GATEWAY_INTERFACE'],服务器使用的 CGI 规范的版本;例如,"CGI/1.1"。

  • $_SERVER['SERVER_ADDR'],当前运行脚本所在的服务器的 IP 地址。

  • $_SERVER['SERVER_NAME'],当前运行脚本所在的服务器的主机名。如果脚本运行于虚拟主机中,该名称是由那个虚拟主机所设置的值决定。

  • $_SERVER['SERVER_SOFTWARE'],服务器标识字符串,在响应请求时的头信息中给出。 (如:Apache/2.2.24)

  • $_SERVER['SERVER_PROTOCOL'],请求页面时通信协议的名称和版本。例如,"HTTP/1.0"。

  • $_SERVER['REQUEST_METHOD'],访问页面使用的请求方法;例如,"GET", "HEAD","POST","PUT"。

  • $_SERVER['REQUEST_TIME'],请求开始时的时间戳。从 PHP 5.1.0 起可用。 (如:1377687496)

  • $_SERVER['QUERY_STRING'],query string(查询字符串),如果有的话,通过它进行页面访问。

  • $_SERVER['HTTP_ACCEPT'],当前请求头中 Accept: 项的内容,如果存在的话。

  • $_SERVER['HTTP_ACCEPT_CHARSET'],当前请求头中 Accept-Charset: 项的内容,如果存在的话。例如:"iso-8859-1,*,utf-8"。

  • $_SERVER['HTTP_HOST'],当前请求头中 Host: 项的内容,如果存在的话。

  • $_SERVER['HTTP_REFERER'],引导用户代理到当前页的前一页的地址(如果存在)。由 user agent 设置决定。并不是所有的用户代理都会设置该项,有的还提供了修改 HTTP_REFERER 的功能。简言之,该值并不可信。)

  • $_SERVER['HTTPS'],如果脚本是通过 HTTPS 协议被访问,则被设为一个非空的值。

  • $_SERVER['REMOTE_ADDR'],浏览当前页面的用户的 IP 地址。

  • $_SERVER['REMOTE_HOST'],浏览当前页面的用户的主机名。DNS 反向解析不依赖于用户的 REMOTE_ADDR

  • $_SERVER['REMOTE_PORT'],用户机器上连接到 Web 服务器所使用的端口号。

  • $_SERVER['SCRIPT_FILENAME'],当前执行脚本的绝对路径。

  • $_SERVER['SERVER_ADMIN'],该值指明了 Apache 服务器配置文件中的 SERVER_ADMIN 参数。如果脚本运行在一个虚拟主机上,则该值是那个虚拟主机的值。

  • $_SERVER['SERVER_PORT'],Web 服务器使用的端口。默认值为 "80"。如果使用 SSL 安全连接,则这个值为用户设置的 HTTP 端口。

  • $_SERVER['SERVER_SIGNATURE'],包含了服务器版本和虚拟主机名的字符串。

  • $_SERVER['PATH_TRANSLATED'],当前脚本所在文件系统(非文档根目录)的基本路径。这是在服务器进行虚拟到真实路径的映像后的结果。

  • $_SERVER['SCRIPT_NAME'],包含当前脚本的路径。这在页面需要指向自己时非常有用。__FILE__

  • 🎜$_SERVER['SERVER_ADDR'], die IP-Adresse des Servers, auf dem das Skript gerade ausgeführt wird. 🎜🎜🎜$_SERVER['SERVER_NAME'], der Hostname des Servers, auf dem das Skript derzeit ausgeführt wird. Wenn das Skript auf einem virtuellen Host ausgeführt wird, wird der Name durch den für diesen virtuellen Host festgelegten Wert bestimmt. 🎜🎜🎜$_SERVER['SERVER_SOFTWARE'], Server-Identifikationszeichenfolge, die in den Header-Informationen bei der Antwort auf die Anfrage angegeben wird. (Zum Beispiel: Apache/2.2.24)🎜🎜🎜$_SERVER['SERVER_PROTOCOL'], der Name und die Version des Kommunikationsprotokolls beim Anfordern der Seite. Beispiel: „HTTP/1.0“. 🎜🎜🎜$_SERVER['REQUEST_METHOD'], die für den Zugriff auf die Seite verwendete Anforderungsmethode; zum Beispiel „GET“, „HEAD“, „POST“, „PUT“. 🎜🎜🎜$_SERVER['REQUEST_TIME'], der Zeitstempel, als die Anfrage gestartet wurde. Verfügbar ab PHP 5.1.0. (Zum Beispiel: 1377687496)🎜🎜🎜$_SERVER['QUERY_STRING'], Abfragezeichenfolge (Abfragezeichenfolge), falls vorhanden, wird der Seitenzugriff darüber durchgeführt. 🎜🎜🎜$_SERVER['HTTP_ACCEPT'], der Inhalt des Accept:-Elements im aktuellen Anforderungsheader, falls vorhanden. 🎜🎜🎜$_SERVER['HTTP_ACCEPT_CHARSET'], der Inhalt des Accept-Charset:-Elements im aktuellen Anforderungsheader, falls vorhanden. Zum Beispiel: „iso-8859-1,*,utf-8“. 🎜🎜🎜$_SERVER['HTTP_HOST'], der Inhalt des Host:-Elements im aktuellen Anforderungsheader, falls vorhanden. 🎜🎜🎜$_SERVER['HTTP_REFERER'], leitet den Benutzeragenten an die Adresse der vorherigen Seite der aktuellen Seite (falls vorhanden). Wird durch die Einstellung Benutzeragent bestimmt. Nicht alle Benutzeragenten legen dieses Element fest, und einige bieten auch die Funktion zum Ändern von HTTP_REFERER. Kurz gesagt, der Wert ist nicht vertrauenswürdig. )🎜🎜🎜$_SERVER['HTTPS'], wird auf einen nicht leeren Wert gesetzt, wenn auf das Skript über das HTTPS-Protokoll zugegriffen wird. 🎜🎜🎜$_SERVER['REMOTE_ADDR'], die IP-Adresse des Benutzers, der die aktuelle Seite durchsucht. 🎜🎜🎜$_SERVER['REMOTE_HOST'], der Hostname des Benutzers, der die aktuelle Seite durchsucht. Die umgekehrte DNS-Auflösung hängt nicht vom REMOTE_ADDR des Benutzers ab. 🎜🎜🎜$_SERVER['REMOTE_PORT'], die Portnummer, die auf dem Computer des Benutzers für die Verbindung zum Webserver verwendet wird. 🎜🎜🎜$_SERVER['SCRIPT_FILENAME'], der absolute Pfad des aktuell ausgeführten Skripts. 🎜🎜🎜$_SERVER['SERVER_ADMIN'], dieser Wert gibt den Parameter SERVER_ADMIN in der Serverkonfigurationsdatei Apache an. Wenn das Skript auf einem virtuellen Host ausgeführt wird, ist dieser Wert der Wert dieses virtuellen Hosts. 🎜🎜🎜$_SERVER['SERVER_PORT'], der vom Webserver verwendete Port. Der Standardwert ist „80“. Bei Verwendung einer sicheren SSL-Verbindung ist dieser Wert der vom Benutzer festgelegte HTTP-Port. 🎜🎜🎜$_SERVER['SERVER_SIGNATURE'], eine Zeichenfolge, die die Serverversion und den Namen des virtuellen Hosts enthält. 🎜🎜🎜$_SERVER['PATH_TRANSLATED'], der Basispfad des Dateisystems (nicht das Stammverzeichnis des Dokuments), in dem sich das aktuelle Skript befindet. Dies ist das Ergebnis, nachdem der Server von einem virtuellen auf einen realen Pfad abgebildet wurde. 🎜🎜🎜$_SERVER['SCRIPT_NAME'], enthält den Pfad des aktuellen Skripts. Dies ist nützlich, wenn die Seite auf sich selbst verweisen muss. Die Konstante __FILE__ enthält den vollständigen Pfad und Dateinamen des aktuellen Skripts (d. h. der Include-Datei). 🎜
  • $_SERVER['SCRIPT_URI'], URI wird verwendet, um die Seite anzugeben, auf die zugegriffen werden soll. Zum Beispiel „/index.html“.

Das ist alles. Wenn Sie noch etwas wissen möchten, können Sie hier klicken. → →php-Video-Tutorial

Das obige ist der detaillierte Inhalt vonBringen Sie Ihnen bei, wie man $_SERVER spielt. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage