php中的server 函數的用法------重點!

來源:互聯網
上載者:User

標籤:http   io   os   ar   使用   sp   檔案   div   on   

$_SERVER 是一個包含了諸如頭資訊(header)、路徑(path)、以及指令碼位置(script locations)等等資訊的數組。這個數組中的項目由 Web 服務器建立。不能保證每個伺服器都提供全部項目;伺服器可能會忽略一些,或者提供一些沒有在這裡列舉出來的項目。下表列出了所有 $_SERVER 變數中的重要元素。 
元素/代碼 描述
$_SERVER[‘PHP_SELF‘] 當前執行指令碼的檔案名稱,與 document root 有關。
$_SERVER[‘GATEWAY_INTERFACE‘] 伺服器使用的 CGI 規範的版本。
$_SERVER[‘SERVER_ADDR‘] 當前運行指令碼所在的伺服器的 IP 位址。
$_SERVER[‘SERVER_NAME‘] 當前運行指令碼所在的伺服器的主機名稱。如果指令碼運行於虛擬機器主機中,該名稱是由那個虛擬機器主機所設定的值決定。
$_SERVER[‘SERVER_SOFTWARE‘] 伺服器標識字串,在響應請求時的頭資訊中給出。
$_SERVER[‘SERVER_PROTOCOL‘] 請求頁面時通訊協定的名稱和版本。
$_SERVER[‘REQUEST_METHOD‘] 訪問頁面使用的要求方法。
$_SERVER[‘REQUEST_TIME‘] 請求開始時的時間戳記。從 PHP 5.1.0 起可用。
$_SERVER[‘QUERY_STRING‘] query string(查詢字串),如果有的話,通過它進行頁面訪問。
$_SERVER[‘HTTP_ACCEPT‘] 當前要求標頭中 Accept: 項的內容,如果存在的話。
$_SERVER[‘HTTP_ACCEPT_CHARSET‘] 當前要求標頭中 Accept-Charset: 項的內容,如果存在的話。
$_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[‘SCRIPT_URI‘] URI 用來指定要訪問的頁面。例如 "/index.html"。

 

下面是某網友整理的結果,可參考下。

伺服器變數 $_SERVER 詳解:

1、$_SESSION[‘PHP_SELF‘] -- 擷取當前正在執行指令碼的檔案名稱

2、$_SERVER[‘SERVER_PROTOCOL‘] -- 請求頁面時通訊協定的名稱和版本。例如,“HTTP/1.0”。

3、$_SERVER[‘REQUEST_TIME‘] -- 請求開始時的時間戳記。從 PHP 5.1.0 起有效。和time函數效果一樣。

4、$_SERVER[‘argv‘] -- 傳遞給該指令碼的參數。我試了下,get方法可以得到$_SERVER[‘argv‘][0];post方法無法給他賦值。

5、$_SERVER[‘SERVER_NAME‘] -- 返回當前主機名稱。

6、$_SERVER[‘SERVER_SOFTWARE‘] -- 伺服器標識的字串,在響應請求時的頭資訊中給出。 如Microsoft-IIS/6.0

7、$_SERVER[‘REQUEST_METHOD‘] -- 訪問頁面時的要求方法。例如:“GET”、“HEAD”,“POST”,“PUT”。

8、$_SERVER[‘QUERY_STRING‘] -- 查詢(query)的字串(URL 中第一個問號 ? 之後的內容)。

9、$_SERVER[‘DOCUMENT_ROOT‘] -- 當前運行指令碼所在的主目錄。在伺服器設定檔中定義。 如E:\server

10、$_SERVER[‘HTTP_ACCEPT‘] -- 當前請求的 Accept: 頭資訊的內容。

11、$_SERVER[‘HTTP_ACCEPT_CHARSET‘] -- 當前請求的 Accept-Charset: 頭資訊的內容。例如:“iso-8859-1,*,utf-8”。

12、$_SERVER[‘HTTP_ACCEPT_ENCODING‘] -- 當前請求的 Accept-Encoding: 頭資訊的內容。例如:“gzip”。

13、$_SERVER[‘HTTP_ACCEPT_LANGUAGE‘] -- 當前請求的 Accept-Language: 頭資訊的內容。例如:“en”。

14、$_SERVER[‘HTTP_CONNECTION‘] -- 當前請求的 Connection: 頭資訊的內容。例如:“Keep-Alive”。

15、$_SERVER[‘HTTP_HOST‘] -- 當前請求的 Host: 頭資訊的內容。

16、$_SERVER[‘HTTP_REFERER‘] -- 連結到當前頁面的前一頁面的 URL 地址。

17、$_SERVER[‘HTTP_USER_AGENT‘] -- 返回使用者使用的瀏覽器資訊。也可以使用 get_browser() 得到此資訊。

18、$_SERVER[‘HTTPS‘] -- 如果通過https訪問,則被設為一個非空的值,否則返回off.

19、$_SERVER[‘REMOTE_ADDR‘] -- 正在瀏覽當前頁面使用者的 IP 位址。

20、$_SERVER[‘REMOTE_HOST‘] -- 正在瀏覽當前頁面使用者的主機名稱。反向網域名稱解析基於該使用者的 REMOTE_ADDR。如本地測試返回127.0.0.1

21、$_SERVER[‘REMOTE_PORT‘] -- 使用者串連到伺服器時所使用的連接埠。我在本機測試沒通過,不知道什麼原因。

22、$_SERVER[‘SCRIPT_FILENAME‘] -- 當前執行指令碼的絕對路徑名。如返回E:\server\index.php

23、$_SERVER[‘SERVER_ADMIN‘] -- 該值指明了 Apache 伺服器設定檔中的 SERVER_ADMIN 參數。如果指令碼運行在一個虛擬機器主機上,則該值是那個虛擬機器主機的值

24、$_SERVER[‘SERVER_PORT‘] -- 伺服器所使用的連接埠。預設為“80”。如果使用 SSL 安全連線,則這個值為使用者佈建的 HTTP 連接埠。

25、$_SERVER[‘SERVER_SIGNATURE‘] -- 包含伺服器版本和虛擬機器主機名的字串。

26、$_SERVER[‘PATH_TRANSLATED‘] -- 當前指令碼所在檔案系統(不是主目錄)的基本路徑。這是在伺服器進行虛擬到真實路徑的映像後的結果。 Apache 2 用 戶可以使用 httpd.conf 中的 AcceptPathInfo On 來定義 PATH_INFO。

27、$_SERVER[‘SCRIPT_NAME‘] -- 包含當前指令碼的路徑。這在頁面需要指向自己時非常有用。__FILE__ 包含當前檔案的絕對路徑和檔案名稱(例如包含檔案)。

28、$_SERVER[‘REQUEST_URI‘] -- 訪問此頁面所需的 URI。例如,“/index.html”。

29、$_SERVER[‘PHP_AUTH_DIGEST‘] -- 當作為 Apache 模組運行時,進行 HTTP Digest 認證的過程中,此變數被設定成用戶端發送的“Authorization”HTTP 頭內容(以便作進一步的認證操作)。

30、$_SERVER[‘PHP_AUTH_USER‘]-- 當 PHP 運行在 Apache 或 IIS(PHP 5 是 ISAPI)模組方式下,並且正在使用 HTTP 認證功能,這個變數便是使用者輸入的使用者名稱。

31、$_SERVER[‘PHP_AUTH_PW‘] -- 當 PHP 運行在 Apache 或 IIS(PHP 5 是 ISAPI)模組方式下,並且正在使用 HTTP 認證功能,這個變數便是使用者輸入的密碼。

32、$_SERVER[‘AUTH_TYPE‘]--當 PHP 運行在 Apache 模組方式下,並且正在使用 HTTP 認證功能,這個變數便是認證的類型。

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.