PHP 超全域變數
$GLOBALS
包含一個引用指向每個當前指令碼的全域範圍內有效變數。該數組的鍵標為全域變數的 名稱。從 PHP 3 開始存在 $GLOBALS 數組。
$_SERVER
變數由 Web 服務器設定或者直接與當前指令碼的執行環境相關聯。類似於舊數組 $HTTP_SERVER_VARS 數組(依然有效,但反對使用)。
$_GET
經由 HTTP GET 方法提交至指令碼的變數。類似於舊數組 $HTTP_GET_VARS 數組(依然有效,但反對使用)。
$_POST
經由 HTTP POST 方法提交至指令碼的變數。類似於舊數組 $HTTP_POST_VARS 數組(依然有效,但反對使用)。
$_COOKIE
經由 HTTP Cookies 方法提交至指令碼的變數。類似於舊數組 $HTTP_COOKIE_VARS 數組(依然有效,但反對使用)。
$_FILES
經由 HTTP POST 檔案上傳而提交至指令碼的變數。類似於舊數組 $HTTP_POST_FILES 數組(依然有效,但反對使用)。詳細資料請參閱 POST 方法上傳。
$_ENV
執行環境提交至指令碼的變數。類似於舊數組 $HTTP_ENV_VARS 數組(依然有效,但反對使用)。
$_REQUEST
經由 GET,POST 和 COOKIE 機制提交至指令碼的變數,因此該數組並不值得信任。所有包含在該數組中的變數的存在與否以及變數的順序均按照 php.ini 中的 variables_order 配置指示來定義。該數組沒有直接類比 PHP 4.1.0 的早期版本。參見 。
******自 PHP 4.3.0 起,$_FILES 中的檔案資訊不再存在於 $_REQUEST 中。*****
$_SESSION
當前註冊給指令碼會話的變數。類似於舊數組 $HTTP_SESSION_VARS 數組(依然有效,但反對使用)。
伺服器變數 $_SERVER 詳解:
1、$_SERVER ['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 地址。不是所有的使用者代理程式(瀏覽器)都會設定這個變數,而且有的還可以手工修改 HTTP_REFERER。因此,這個變數不總是正確真實的。
17、$_SERVER['HTTP_USER_AGENT'] -- 返回使用者使用的瀏覽器資訊。一個典型的例子是:Mozilla/4.5 [en] (X11; U; Linux 2.2.9 i586)。也可以使用 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預定義全域變數$_FILES詳解
經由 HTTP POST 檔案上傳而提交至指令碼的變數。類似於舊數組 $HTTP_POST_FILES 數組(依然有效,但反對使用)。詳細資料請參閱 POST 方法上傳。
$_FILES數組內容如下:
$_FILES['userfile']['name']--- 用戶端機器檔案的原名稱。
$_FILES['userfile']['type'] ---檔案的 MIME 類型,需要瀏覽器提供該資訊的支援,例如“image/gif”。
$_FILES['userfile']['size']--- 已上傳檔案的大小,單位為位元組。
$_FILES['userfile']['tmp_name']---檔案被上傳後在服務端儲存的臨時檔案名稱。
$_FILES['userfile']['error']---和該檔案上傳相關的錯誤碼。['error'] 是在 PHP 4.2.0 版本中增加的。
注: 在 PHP 4.1.0 版本以前該數組的名稱為 $HTTP_POST_FILES,它並不像 $_FILES 一樣是自動全域變數。PHP 3 不支援 $HTTP_POST_FILES 數組。
http://www.bkjia.com/PHPjc/477360.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/477360.htmlTechArticlePHP 超全域變數 $GLOBALS 包含一個引用指向每個當前指令碼的全域範圍內有效變數。該數組的鍵標為全域變數的 名稱。從 PHP 3 開始存在 $GLO...