您好,登錄后才能下訂單哦!
這篇文章主要講解了“PHP超全局變量實現原理是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“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="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>
感謝各位的閱讀,以上就是“PHP超全局變量實現原理是什么”的內容了,經過本文的學習后,相信大家對PHP超全局變量實現原理是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。