雷林鵬分享:PHP 超級全局變量 -开发者知识库

雷林鵬分享:PHP 超級全局變量 -开发者知识库,第1张

  超級全局變量在PHP 4.1.0之后被啟用, 是PHP系統中自帶的變量,在一個腳本的全部作用域中都可用。

  PHP 超級全局變量

  PHP中預定義了幾個超級全局變量(superglobals) ,這意味着它們在一個腳本的全部作用域中都可用。 你不需要特別說明,就可以在函數及類中使用。

  PHP 超級全局變量列表:

  $GLOBALS

  $_SERVER

  $_REQUEST

  $_POST

  $_GET

  $_FILES

  $_ENV

  $_COOKIE

  $_SESSION

  本章節我們將講解幾個常用的超級全局變量,其余變量我們在接下來幾個章節會介紹到。

  PHP $GLOBALS

  $GLOBALS 是PHP的一個超級全局變量組,在一個PHP腳本的全部作用域中都可以訪問。

  $GLOBALS 是一個包含了全部變量的全局組合數組。變量的名字就是數組的鍵。

  以下實例介紹了如何使用超級全局變量 $GLOBALS:

  

  $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中的元素:

  

  echo $_SERVER['PHP_SELF'];

  echo "
";

  echo $_SERVER['SERVER_NAME'];

  echo "
";

  echo $_SERVER['HTTP_HOST'];

  echo "
";

  echo $_SERVER['HTTP_REFERER'];

  echo "
";

  echo $_SERVER['HTTP_USER_AGENT'];

  echo "
";

  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.codercto.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 參數。如果腳本運行在一個虛擬主機上,則該值是那個虛擬主機的值。(如:someone@codercto.com)

  $_SERVER['SERVER_PORT']Web 服務器使用的端口。默認值為 "80"。如果使用 SSL 安全連接,則這個值為用戶設置的 HTTP 端口。

  $_SERVER['SERVER_SIGNATURE']包含了服務器版本和虛擬主機名的字符串。

  $_SERVER['PATH_TRANSLATED']當前腳本所在文件系統(非文檔根目錄)的基本路徑。這是在服務器進行虛擬到真實路徑的映像后的結果。

  $_SERVER['SCRIPT_NAME']包含當前腳本的路徑。這在頁面需要指向自己時非常有用。__FILE__ 常量包含當前腳本(例如包含文件)的完整路徑和文件名。

  $_SERVER['SCRIPT_URI']URI 用來指定要訪問的頁面。例如 "/index.html"。

  PHP $_REQUEST

  PHP $_REQUEST 用於收集HTML表單提交的數據。

  以下實例顯示了一個輸入字段(input)及提交按鈕(submit)的表單(form)。 當用戶通過點擊 "Submit" 按鈕提交表單數據時, 表單數據將發送至

標簽中 action 屬性中指定的腳本文件。 在這個實例中,我們指定文件來處理表單數據。如果你希望其他的PHP文件來處理該數據,你可以修改該指定的腳本文件名。 然后,我們可以使用超級全局變量 $_REQUEST 來收集表單中的 input 字段數據:

 

  

  

  

  Name:

  

  

 

  

  

  

  PHP $_POST

  PHP $_POST 被廣泛應用於收集表單數據,在HTML form標簽的指定該屬性:"method="post"。

  以下實例顯示了一個輸入字段(input)及提交按鈕(submit)的表單(form)。 當用戶通過點擊 "Submit" 按鈕提交表單數據時, 表單數據將發送至

標簽中 action 屬性中指定的腳本文件。 在這個實例中,我們指定文件來處理表單數據。如果你希望其他的PHP文件來處理該數據,你可以修改該指定的腳本文件名。 然后,我們可以使用超級全局變量 $_POST 來收集表單中的 input 字段數據:

 

  

  

  

  Name:

  

  

 

  

  

  

  PHP $_GET

  PHP $_GET 同樣被廣泛應用於收集表單數據,在HTML form標簽的指定該屬性:"method="get"。

  $_GET 也可以收集URL中發送的數據。

  假定我們有一個包含參數的超鏈接HTML頁面:

  

  

  Test $GET

  

  

  當用戶點擊鏈接 "Test $GET", 參數 "subject" 和 "web" 將發送至"test_get.php",你可以在 "test_get.php" 文件中使用 $_GET 變量來獲取這些數據。

  以下實例顯示了 "test_get.php" 文件的代碼:

  

  

  

  

  

  提示: 你如果想學習更多關於 $_POST 和 $_GET 的知識,請訪問我們的 PHP 表單 章節。

  點擊查看所有 PHP 教程 文章: https://www.codercto.com/courses/l/5.html(編輯:雷林鵬 來源:網絡 侵刪)

最佳答案:

本文经用户投稿或网站收集转载,如有侵权请联系本站。

发表评论

0条回复