PHP 超級全局變量
PHP中預定義了幾個超級全局變量(superglobals) ,這意味著它們在一個腳本的全部作用域中都可用。特別說明,就可以在函數及類中使用。
PHP 超級全局變量列表:
$GLOBALS 是一個包含了全部變量的全局組合數組。變量的名字就是數組的鍵。
$_SERVER 包含了諸如頭信息(header)、路徑(path)等等信息的數組。
$_REQUEST 用於收集HTML表單提交的數據。
$_POST 被廣泛應用於收集表單數據
$_GET 被廣泛應用於收集表單數據可以收集URL中發送的數據。
$_FILES
$_ENV
$_COOKIE
$_SESSION
$GLOBALS
$GLOBALS 是PHP的一個超級全局變量組,在一個PHP腳本的全部作用域中都可以訪問。$GLOBALS 是一個包含了全部變量的全局組合數組。變量的名字就是數組的鍵。(可以參考另一篇文章:PHP $GLOBALS超全局變量分析)
以下實例介紹了如何使用超級全局變量 $GLOBALS:
<?php $x = 75; $y = 25; function addition() { $GLOBALS[‘z‘] = $GLOBALS[‘x‘] + $GLOBALS[‘y‘]; } addition(); echo $z; ?>
以上實例中 z 是一個$GLOBALS數組中的超級全局變量,該變量同樣可以在函數外訪問。
PHP $_SERVER
$_SERVER 是一個包含了諸如頭信息(header)、路徑(path)、以及腳本位置(script locations)等等信息的數組。這個數組中的項目由 Web 服務器創
建。不能保證每個服務器都提供全部項目;服務器可能會忽略一些,或者提供一些沒有在這裏列舉出來的項目。以下實例中展示了如何使
用$_SERVER中的元素:
<?php echo $_SERVER[‘PHP_SELF‘]; echo "<br>"; echo $_SERVER[‘SERVER_NAME‘]; echo "<br>"; echo $_SERVER[‘HTTP_HOST‘];echo "<br>"; echo $_SERVER[‘HTTP_REFERER‘]; echo "<br>"; echo $_SERVER[‘HTTP_USER_AGENT‘]; echo "<br>"; echo $_SERVER[‘SCRIPT_NAME‘]; ?>
下表列出了所有 $_SERVER 變量中的重要元素:
元素/代碼 | 描述 |
$_SERVER[‘PHP_SELF‘] | 當前執行腳本的文件名,與 document root 有關。例如,在地址為 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‘] | 當前運行腳本所在的服務器的主機名。如果腳本運行於虛擬主機中,該名稱是由那個虛擬主機所設置的值決定。(如: www.runoob.com) |
$_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 參數。如果腳本運行在一個虛擬主機上,則該值是那個虛擬主機的值。(如:[email protected]) |
$_SERVER[‘SERVER_PORT‘] | Web 服務器使用的端口。默認值為 "80"。如果使用 SSL 安全連接,則這個值為用戶設置的 HTTP 端口。 |
$_SERVER[‘SERVER_SIGNATURE‘] | 包含了服務器版本和虛擬主機名的字符串。 |
$_SERVER[‘PATH_TRANSLATED‘] | 當前腳本所在文件系統(非文檔根目錄)的基本路徑。這是在服務器進行虛擬到真實路徑的映像後的結果。 |
$_SERVER[‘SCRIPT_NAME‘] | 包含當前腳本的路徑。這在頁面需要指向自己時非常有用。__FILE__ 常量包含當前腳本(例如包含文件)的完整路徑和文件名。 |
$_SERVER[‘SCRIPT_URI‘] | URI 用來指定要訪問的頁面。例如 "/index.html"。 |
$_REQUEST
PHP $_REQUEST 用於收集HTML表單提交的數據。
以下實例顯示了一個輸入字段(input)及提交按鈕(submit)的表單(form)。 當用戶通過點擊 "Submit" 按鈕提交表單數據時, 表單數據將發送至<form>