PHP中$_SERVER的詳細用法

來源:互聯網
上載者:User
本篇文章的內容是PHP中$_SERVER的詳細用法,現在分享給大家,也可以給有需要的朋友一個參考

$_SERVER['PHP_SELF'] #當前正在執行指令碼的檔案名稱,與 document root相關。
$_SERVER['argv'] #傳遞給該指令碼的參數。
$_SERVER['argc'] #包含傳遞給程式的命令列參數的個數(如果運行在命令列模式)。
$_SERVER['GATEWAY_INTERFACE'] #伺服器使用的 CGI 規範的版本。例如,“CGI/1.1”。
$_SERVER['SERVER_NAME'] #當前運行指令碼所在伺服器主機的名稱。
$_SERVER['SERVER_SOFTWARE'] #伺服器標識的字串,在響應請求時的頭部中給出。
$_SERVER['SERVER_PROTOCOL'] #請求頁面時通訊協定的名稱和版本。例如,“HTTP/1.0”。
$_SERVER['REQUEST_METHOD'] #訪問頁面時的要求方法。例如:“GET”、“HEAD”,“POST”,“PUT”。
$_SERVER['QUERY_STRING'] #查詢(query)的字串。
$_SERVER['DOCUMENT_ROOT'] #當前運行指令碼所在的主目錄。在伺服器設定檔中定義。
$_SERVER['HTTP_ACCEPT'] #當前請求的 Accept: 頭部的內容。
$_SERVER['HTTP_ACCEPT_CHARSET'] #當前請求的 Accept-Charset: 頭部的內容。例如:“iso-8859-1,*,utf-8”。
$_SERVER['HTTP_ACCEPT_ENCODING'] #當前請求的 Accept-Encoding: 頭部的內容。例如:“gzip”。
$_SERVER['HTTP_ACCEPT_LANGUAGE']#當前請求的 Accept-Language: 頭部的內容。例如:“en”。
$_SERVER['HTTP_CONNECTION'] #當前請求的 Connection: 頭部的內容。例如:“Keep-Alive”。
$_SERVER['HTTP_HOST'] #當前請求的 Host: 頭部的內容。
$_SERVER['HTTP_REFERER'] #連結到當前頁面的前一頁面的 URL 地址。
$_SERVER['HTTP_USER_AGENT'] #當前請求的 User_Agent: 頭部的內容。
$_SERVER['HTTPS'] — 如果通過https訪問,則被設為一個非空的值(on),否則返回off
$_SERVER['REMOTE_ADDR'] #正在瀏覽當前頁面使用者的 IP 位址。
$_SERVER['REMOTE_HOST'] #正在瀏覽當前頁面使用者的主機名稱。
$_SERVER['REMOTE_PORT'] #使用者串連到伺服器時所使用的連接埠。
$_SERVER['SCRIPT_FILENAME'] #當前執行指令碼的絕對路徑名。
$_SERVER['SERVER_ADMIN'] #管理員資訊
$_SERVER['SERVER_PORT'] #伺服器所使用的連接埠
$_SERVER['SERVER_SIGNATURE'] #包含伺服器版本和虛擬機器主機名的字串。
$_SERVER['PATH_TRANSLATED'] #當前指令碼所在檔案系統(不是主目錄)的基本路徑。
$_SERVER['SCRIPT_NAME'] #包含當前指令碼的路徑。這在頁面需要指向自己時非常有用。
$_SERVER['REQUEST_URI'] #訪問此頁面所需的 URI。例如,“/index.html”。
$_SERVER['PHP_AUTH_USER'] #當 PHP 運行在 Apache 模組方式下,並且正在使用 HTTP 認證功能,這個變數便是使用者輸入的使用者名稱。
$_SERVER['PHP_AUTH_PW'] #當 PHP 運行在 Apache 模組方式下,並且正在使用 HTTP 認證功能,這個變數便是使用者輸入的密碼。
$_SERVER['AUTH_TYPE'] #當 PHP 運行在 Apache 模組方式下,並且正在使用 HTTP 認證功能,這個變數便是認證的類型。
$_SERVER[”HTTP_X_FORWARDED_FOR”] #透過Proxy 伺服器取得用戶端的真實 IP 位址
$_SERVER['HTTP_VIA'] #Proxy 伺服器IP
$_SERVER['HTTP_CLIENT_IP'] #用戶端IP

伺服器變數:$_SERVER

注: 在 PHP 4.1.0 及以後版本使用。之前的版本,使用 $HTTP_SERVER_VARS。

$_SERVER 是一個包含諸如頭部(headers)、路徑(paths)和指令碼位置(script locations)的數組。數組的實體由 網頁伺服器建立。不能保證所有的伺服器都能產生所有的資訊;伺服器可能忽略了一些資訊,或者產生了一些未在下面列出的新的資訊。這意味著,大量的這些變數在 CGI 1.1 specification 中說明,所以您應該仔細研究它。

這是一個“superglobal”,或者可以描述為自動全域變數。這隻不過意味這它在所有的指令碼中都有效。在函數或方法中您不需要使用 global $_SERVER; 訪問它,就如同使用 $HTTP_SERVER_VARS 一樣。

$HTTP_SERVER_VARS 包含著同樣的資訊,但是不是一個自動全域變數。(注意: $HTTP_SERVER_VARS 和 $_SERVER 是不同的變數,PHP 處理它們的方式不同。)

如果設定了 register_globals 指令,這些變數也在所有指令碼中可用;也就是,分離了 $_SERVER 和 $HTTP_SERVER_VARS 數組。相關資訊,請參閱安全的相關章節 使用 Register Globals。這些單獨的全域變數不是自動全域變數。

您或許會發現下面列出的某些 $_SERVER 元素並不可用。注意,如果以命令列方式運行 PHP,下面列出的元素幾乎沒有有效(或是沒有任何實際意義的)。

“PHP_SELF”
當前正在執行指令碼的檔案名稱,與 document root相關。舉例來說,在URL地址為http://easyboor.com/test.php/foo.bar 的指令碼中使用 $_SERVER['PHP_SELF'] 將會得到 /test.php/foo.bar 這個結果。

如果 PHP 以命令列方式運行,該變數無效。

“argv”
傳遞給該指令碼的參數。當指令碼運行在命令列方式時,argv 變數傳遞給程式 C 語言樣式的命令列參數。當調用 GET 方法時,該變數包含請求的資料。

“argc”
包含傳遞給程式的命令列參數的個數(如果運行在命令列模式)。

“GATEWAY_INTERFACE”
伺服器使用的 CGI 規範的版本。例如,“CGI/1.1”。

'SERVER_NAME'
當前運行指令碼所在伺服器主機的名稱。如果該指令碼運行在一個虛擬機器主機上,該名稱是由那個虛擬機器主機所設定的值決定。

'SERVER_SOFTWARE'
伺服器標識的字串,在響應請求時的頭部中給出。

“SERVER_PROTOCOL”
請求頁面時通訊協定的名稱和版本。例如,“HTTP/1.0”。

“REQUEST_METHOD”
訪問頁面時的要求方法。例如:“GET”、“HEAD”,“POST”,“PUT”。

“QUERY_STRING”
查詢(query)的字串。

“DOCUMENT_ROOT”
當前運行指令碼所在的主目錄。在伺服器設定檔中定義。

“HTTP_ACCEPT”
當前請求的 Accept: 頭部的內容。

“HTTP_ACCEPT_CHARSET”
當前請求的 Accept-Charset: 頭部的內容。例如:“iso-8859-1,*,utf-8”。

“HTTP_ACCEPT_ENCODING”
當前請求的 Accept-Encoding: 頭部的內容。例如:“gzip”。

“HTTP_ACCEPT_LANGUAGE”
當前請求的 Accept-Language: 頭部的內容。例如:“en”。

“HTTP_CONNECTION”
當前請求的 Connection: 頭部的內容。例如:“Keep-Alive”。

“HTTP_HOST”
當前請求的 Host: 頭部的內容。

“HTTP_REFERER”
連結到當前頁面的前一頁面的 URL 地址。不是所有的使用者代理程式(瀏覽器)都會設定這個變數,而且有的還可以手工修改 HTTP_REFERER。因此,這個變數不總是正確真實的。

“HTTP_USER_AGENT”
當前請求的 User_Agent: 頭部的內容。該字串表明了訪問該頁面的使用者代理程式的資訊。一個典型的例子是:Mozilla/4.5 [en] (X11; U; Linux 2.2.9 i586)。您也可以使用 get_browser() 得到這個資訊。

“REMOTE_ADDR”
正在瀏覽當前頁面使用者的 IP 位址。

'REMOTE_HOST'
正在瀏覽當前頁面使用者的主機名稱。反向網域名稱解析基於該使用者的 REMOTE_ADDR。

注: 必須配置 Web 服務器來建立此變數。例如 Apache 需要在 httpd.conf 中有 HostnameLookups On。參見 gethostbyaddr()。

“REMOTE_PORT”
使用者串連到伺服器時所使用的連接埠。

“SCRIPT_FILENAME”
當前執行指令碼的絕對路徑名。

“SERVER_ADMIN”
該值指明了 Apache 伺服器設定檔中的 SERVER_ADMIN 參數。如果指令碼運行在一個虛擬機器主機上,則該值是那個虛擬機器主機的值。

“SERVER_PORT”
伺服器所使用的連接埠。預設為“80”。如果你使用 SSL 安全連線,則這個值為您所設定的 HTTP 連接埠。

“SERVER_SIGNATURE”
包含伺服器版本和虛擬機器主機名的字串。

“PATH_TRANSLATED”
當前指令碼所在檔案系統(不是主目錄)的基本路徑。這是在伺服器進行虛擬到真實路徑的映像後的結果。

“SCRIPT_NAME”
包含當前指令碼的路徑。這在頁面需要指向自己時非常有用。

“REQUEST_URI”
訪問此頁面所需的 URI。例如,“/index.html”。

“PHP_AUTH_USER”
當 PHP 運行在 Apache 模組方式下,並且正在使用 HTTP 認證功能,這個變數便是使用者輸入的使用者名稱。

“PHP_AUTH_PW”
當 PHP 運行在 Apache 模組方式下,並且正在使用 HTTP 認證功能,這個變數便是使用者輸入的密碼。

“AUTH_TYPE”
當 PHP 運行在 Apache 模組方式下,並且正在使用 HTTP 認證功能,這個變數便是認證的類型。

相關推薦:

PHP中$_SERVER的使用總結分享

細說PHP中的$_SERVER

php之$_SERVER函數解析


聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.