PHP超全局變量實現原理及代碼解析
超全局變量在 PHP 4.1.0 中引入,是在全部作用域中始終可用的內置變量。
PHP 超全局變量
PHP 中的許多預定義變量都是“超全局的”,這意味著它們在一個腳本的全部作用域中都可用。在函數或方法中無需執行 global $variable; 就可以訪問它們。
這些超全局變量是:
$GLOBALS $_SERVER $_REQUEST $_POST $_GET $_FILES $_ENV $_COOKIE $_SESSION本節會介紹一些超全局變量,并會在稍后的章節講解其他的超全局變量。
$GLOBALS — 引用全局作用域中可用的全部變量
$GLOBALS 這種全局變量用于在 PHP 腳本中的任意位置訪問全局變量(從函數或方法中均可)。
PHP 在名為 $GLOBALS[index] 的數組中存儲了所有全局變量。變量的名字就是數組的鍵。
下面的例子展示了如何使用超級全局變量 $GLOBALS:
實例
<?php $x = 75; $y = 25; function addition() { $GLOBALS[’z’] = $GLOBALS[’x’] + $GLOBALS[’y’]; } addition(); echo $z; ?>
在上面的例子中,由于 z 是 $GLOBALS 數組中的變量,因此在函數之外也可以訪問它。
PHP $_SERVER
$_SERVER 這種超全局變量保存關于報頭、路徑和腳本位置的信息。
下面的例子展示了如何使用 $_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’] 返回當前執行腳本的文件名。 $_SERVER[’GATEWAY_INTERFACE’] 返回服務器使用的 CGI 規范的版本。 $_SERVER[’SERVER_ADDR’] 返回當前運行腳本所在的服務器的 IP 地址。 $_SERVER[’SERVER_NAME’] 返回當前運行腳本所在的服務器的主機名(比如 www.w3school.com.cn)。 $_SERVER[’SERVER_SOFTWARE’] 返回服務器標識字符串(比如 Apache/2.2.24)。 $_SERVER[’SERVER_PROTOCOL’] 返回請求頁面時通信協議的名稱和版本(例如,“HTTP/1.0”)。 $_SERVER[’REQUEST_METHOD’] 返回訪問頁面使用的請求方法(例如 POST)。 $_SERVER[’REQUEST_TIME’] 返回請求開始時的時間戳(例如 1577687494)。 $_SERVER[’QUERY_STRING’] 返回查詢字符串,如果是通過查詢字符串訪問此頁面。 $_SERVER[’HTTP_ACCEPT’] 返回來自當前請求的請求頭。 $_SERVER[’HTTP_ACCEPT_CHARSET’] 返回來自當前請求的 Accept_Charset 頭( 例如 utf-8,ISO-8859-1) $_SERVER[’HTTP_HOST’] 返回來自當前請求的 Host 頭。 $_SERVER[’HTTP_REFERER’] 返回當前頁面的完整 URL(不可靠,因為不是所有用戶代理都支持)。 $_SERVER[’HTTPS’] 是否通過安全 HTTP 協議查詢腳本。 $_SERVER[’REMOTE_ADDR’] 返回瀏覽當前頁面的用戶的 IP 地址。 $_SERVER[’REMOTE_HOST’] 返回瀏覽當前頁面的用戶的主機名。 $_SERVER[’REMOTE_PORT’] 返回用戶機器上連接到 Web 服務器所使用的端口號。 $_SERVER[’SCRIPT_FILENAME’] 返回當前執行腳本的絕對路徑。 $_SERVER[’SERVER_ADMIN’] 該值指明了 Apache 服務器配置文件中的 SERVER_ADMIN 參數。 $_SERVER[’SERVER_PORT’] Web 服務器使用的端口。默認值為 “80”。 $_SERVER[’SERVER_SIGNATURE’] 返回服務器版本和虛擬主機名。 $_SERVER[’PATH_TRANSLATED’] 當前腳本所在文件系統(非文檔根目錄)的基本路徑。 $_SERVER[’SCRIPT_NAME’] 返回當前腳本的路徑。 $_SERVER[’SCRIPT_URI’] 返回當前頁面的 URI。
PHP $_REQUEST
PHP $_REQUEST 用于收集 HTML 表單提交的數據。
下面的例子展示了一個包含輸入字段及提交按鈕的表單。當用戶通過點擊提交按鈕來提交表單數據時, 表單數據將發送到 標簽的 action 屬性中指定的腳本文件。在這個例子中,我們指定文件本身來處理表單數據。如果您需要使用其他的 PHP 文件來處理表單數據,請修改為您選擇的文件名即可。然后,我們可以使用超級全局變量 $_REQUEST 來收集 input 字段的值:
實例
<html><body><form method='post' action='<?php echo $_SERVER[’PHP_SELF’];?>'>Name: <input type='text' name='fname'><input type='submit'></form><?php $name = $_REQUEST[’fname’]; echo $name; ?></body></html>
PHP $_POST
PHP $_POST 廣泛用于收集提交 method='post' 的 HTML 表單后的表單數據。$_POST 也常用于傳遞變量。
下面的例子展示了一個包含輸入字段和提交按鈕的表單。當用戶點擊提交按鈕來提交數據后,表單數據會發送到 標簽的 action 屬性中指定的文件。在本例中,我們指定文件本身來處理表單數據。如果您希望使用另一個 PHP 頁面來處理表單數據,請用更改為您選擇的文件名。然后,我們可以使用超全局變量 $_POST 來收集輸入字段的值:
實例
<html><body><form method='post' action='<?php echo $_SERVER[’PHP_SELF’];?>'>Name: <input type='text' name='fname'><input type='submit'></form><?php $name = $_POST[’fname’];echo $name; ?></body></html>
PHP $_GET
PHP $_GET 也可用于收集提交 HTML 表單 (method='get') 之后的表單數據。
$_GET 也可以收集 URL 中的發送的數據。
假設我們有一張頁面含有帶參數的超鏈接:
<html><body><a href='http://www.cgvv.com.cn/bcjs/test_get.php?subject=PHP&web=W3school.com.cn' rel='external nofollow' >測試 $GET</a></body></html>
當用戶點擊鏈接 '測試 $GET',參數 'subject' 和 'web' 被發送到 'test_get.php',然后您就能夠通過 $_GET 在 'test_get.php' 中訪問這些值了。
下面的例子是 'test_get.php' 中的代碼:
實例
<html><body><?php echo '在 ' . $_GET[’web’] . ' 學習 ' . $_GET[’subject’];?></body></html>
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。
相關文章: