這篇文章主要講解了“PHP超全局變量實(shí)現(xiàn)原理是什么”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“PHP超全局變量實(shí)現(xiàn)原理是什么”吧!
我們提供的服務(wù)有:網(wǎng)站制作、成都做網(wǎng)站、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、汝州ssl等。為上千多家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的汝州網(wǎng)站制作公司超全局變量在 PHP 4.1.0 中引入,是在全部作用域中始終可用的內(nèi)置變量。
PHP 超全局變量
PHP 中的許多預(yù)定義變量都是“超全局的”,這意味著它們在一個(gè)腳本的全部作用域中都可用。在函數(shù)或方法中無需執(zhí)行 global $variable; 就可以訪問它們。
這些超全局變量是:
$GLOBALS
$_SERVER
$_REQUEST
$_POST
$_GET
$_FILES
$_ENV
$_COOKIE
$_SESSION
本節(jié)會介紹一些超全局變量,并會在稍后的章節(jié)講解其他的超全局變量。
$GLOBALS — 引用全局作用域中可用的全部變量
$GLOBALS 這種全局變量用于在 PHP 腳本中的任意位置訪問全局變量(從函數(shù)或方法中均可)。
PHP 在名為 $GLOBALS[index] 的數(shù)組中存儲了所有全局變量。變量的名字就是數(shù)組的鍵。
下面的例子展示了如何使用超級全局變量 $GLOBALS:
實(shí)例
<?php $x = 75; $y = 25; function addition() { $GLOBALS['z'] = $GLOBALS['x'] + $GLOBALS['y']; } addition(); echo $z; ?>
在上面的例子中,由于 z 是 $GLOBALS 數(shù)組中的變量,因此在函數(shù)之外也可以訪問它。
PHP $_SERVER
$_SERVER 這種超全局變量保存關(guān)于報(bào)頭、路徑和腳本位置的信息。
下面的例子展示了如何使用 $_SERVER 中的某些元素:
實(shí)例
<?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'] | 返回當(dāng)前執(zhí)行腳本的文件名。 |
$_SERVER['GATEWAY_INTERFACE'] | 返回服務(wù)器使用的 CGI 規(guī)范的版本。 |
$_SERVER['SERVER_ADDR'] | 返回當(dāng)前運(yùn)行腳本所在的服務(wù)器的 IP 地址。 |
$_SERVER['SERVER_NAME'] | 返回當(dāng)前運(yùn)行腳本所在的服務(wù)器的主機(jī)名(比如 www.w3school.com.cn)。 |
$_SERVER['SERVER_SOFTWARE'] | 返回服務(wù)器標(biāo)識字符串(比如 Apache/2.2.24)。 |
$_SERVER['SERVER_PROTOCOL'] | 返回請求頁面時(shí)通信協(xié)議的名稱和版本(例如,“HTTP/1.0”)。 |
$_SERVER['REQUEST_METHOD'] | 返回訪問頁面使用的請求方法(例如 POST)。 |
$_SERVER['REQUEST_TIME'] | 返回請求開始時(shí)的時(shí)間戳(例如 1577687494)。 |
$_SERVER['QUERY_STRING'] | 返回查詢字符串,如果是通過查詢字符串訪問此頁面。 |
$_SERVER['HTTP_ACCEPT'] | 返回來自當(dāng)前請求的請求頭。 |
$_SERVER['HTTP_ACCEPT_CHARSET'] | 返回來自當(dāng)前請求的 Accept_Charset 頭( 例如 utf-8,ISO-8859-1) |
$_SERVER['HTTP_HOST'] | 返回來自當(dāng)前請求的 Host 頭。 |
$_SERVER['HTTP_REFERER'] | 返回當(dāng)前頁面的完整 URL(不可靠,因?yàn)椴皇撬杏脩舸矶贾С郑?/td> |
$_SERVER['HTTPS'] | 是否通過安全 HTTP 協(xié)議查詢腳本。 |
$_SERVER['REMOTE_ADDR'] | 返回瀏覽當(dāng)前頁面的用戶的 IP 地址。 |
$_SERVER['REMOTE_HOST'] | 返回瀏覽當(dāng)前頁面的用戶的主機(jī)名。 |
$_SERVER['REMOTE_PORT'] | 返回用戶機(jī)器上連接到 Web 服務(wù)器所使用的端口號。 |
$_SERVER['SCRIPT_FILENAME'] | 返回當(dāng)前執(zhí)行腳本的絕對路徑。 |
$_SERVER['SERVER_ADMIN'] | 該值指明了 Apache 服務(wù)器配置文件中的 SERVER_ADMIN 參數(shù)。 |
$_SERVER['SERVER_PORT'] | Web 服務(wù)器使用的端口。默認(rèn)值為 “80”。 |
$_SERVER['SERVER_SIGNATURE'] | 返回服務(wù)器版本和虛擬主機(jī)名。 |
$_SERVER['PATH_TRANSLATED'] | 當(dāng)前腳本所在文件系統(tǒng)(非文檔根目錄)的基本路徑。 |
$_SERVER['SCRIPT_NAME'] | 返回當(dāng)前腳本的路徑。 |
$_SERVER['SCRIPT_URI'] | 返回當(dāng)前頁面的 URI。 |
PHP $_REQUEST
PHP $_REQUEST 用于收集 HTML 表單提交的數(shù)據(jù)。
下面的例子展示了一個(gè)包含輸入字段及提交按鈕的表單。當(dāng)用戶通過點(diǎn)擊提交按鈕來提交表單數(shù)據(jù)時(shí), 表單數(shù)據(jù)將發(fā)送到 標(biāo)簽的 action 屬性中指定的腳本文件。在這個(gè)例子中,我們指定文件本身來處理表單數(shù)據(jù)。如果您需要使用其他的 PHP 文件來處理表單數(shù)據(jù),請修改為您選擇的文件名即可。然后,我們可以使用超級全局變量 $_REQUEST 來收集 input 字段的值:
實(shí)例
<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 表單后的表單數(shù)據(jù)。$_POST 也常用于傳遞變量。
下面的例子展示了一個(gè)包含輸入字段和提交按鈕的表單。當(dāng)用戶點(diǎn)擊提交按鈕來提交數(shù)據(jù)后,表單數(shù)據(jù)會發(fā)送到 標(biāo)簽的 action 屬性中指定的文件。在本例中,我們指定文件本身來處理表單數(shù)據(jù)。如果您希望使用另一個(gè) PHP 頁面來處理表單數(shù)據(jù),請用更改為您選擇的文件名。然后,我們可以使用超全局變量 $_POST 來收集輸入字段的值:
實(shí)例
<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") 之后的表單數(shù)據(jù)。
$_GET 也可以收集 URL 中的發(fā)送的數(shù)據(jù)。
假設(shè)我們有一張頁面含有帶參數(shù)的超鏈接:
<html> <body> <a href="test_get.php?subject=PHP&web=W3school.com.cn" rel="external nofollow" >測試 $GET</a> </body> </html>
當(dāng)用戶點(diǎn)擊鏈接 "測試 $GET",參數(shù) "subject" 和 "web" 被發(fā)送到 "test_get.php",然后您就能夠通過 $_GET 在 "test_get.php" 中訪問這些值了。
下面的例子是 "test_get.php" 中的代碼:
實(shí)例
<html> <body> <?php echo "在 " . $_GET['web'] . " 學(xué)習(xí) " . $_GET['subject']; ?> </body> </html>
感謝各位的閱讀,以上就是“PHP超全局變量實(shí)現(xiàn)原理是什么”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對PHP超全局變量實(shí)現(xiàn)原理是什么這一問題有了更深刻的體會,具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!
文章名稱:PHP超全局變量實(shí)現(xiàn)原理是什么-創(chuàng)新互聯(lián)
網(wǎng)站網(wǎng)址:http://bm7419.com/article40/diciho.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、品牌網(wǎng)站設(shè)計(jì)、自適應(yīng)網(wǎng)站、搜索引擎優(yōu)化、微信公眾號、服務(wù)器托管
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容