欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP超全局變量實現(xiàn)原理及代碼解析

 更新時間:2020年09月01日 10:18:20   投稿:yaominghui  
這篇文章主要介紹了PHP超全局變量實現(xiàn)原理及代碼解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

超全局變量在 PHP 4.1.0 中引入,是在全部作用域中始終可用的內(nèi)置變量。

PHP 超全局變量

PHP 中的許多預(yù)定義變量都是“超全局的”,這意味著它們在一個腳本的全部作用域中都可用。在函數(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:

實例

<?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)于報頭、路徑和腳本位置的信息。

下面的例子展示了如何使用 $_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'] 返回當(dāng)前執(zhí)行腳本的文件名。
$_SERVER['GATEWAY_INTERFACE'] 返回服務(wù)器使用的 CGI 規(guī)范的版本。
$_SERVER['SERVER_ADDR'] 返回當(dāng)前運行腳本所在的服務(wù)器的 IP 地址。
$_SERVER['SERVER_NAME'] 返回當(dāng)前運行腳本所在的服務(wù)器的主機名(比如 www.w3school.com.cn)。
$_SERVER['SERVER_SOFTWARE'] 返回服務(wù)器標(biāo)識字符串(比如 Apache/2.2.24)。
$_SERVER['SERVER_PROTOCOL'] 返回請求頁面時通信協(xié)議的名稱和版本(例如,“HTTP/1.0”)。
$_SERVER['REQUEST_METHOD'] 返回訪問頁面使用的請求方法(例如 POST)。
$_SERVER['REQUEST_TIME'] 返回請求開始時的時間戳(例如 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(不可靠,因為不是所有用戶代理都支持)。
$_SERVER['HTTPS'] 是否通過安全 HTTP 協(xié)議查詢腳本。
$_SERVER['REMOTE_ADDR'] 返回瀏覽當(dāng)前頁面的用戶的 IP 地址。
$_SERVER['REMOTE_HOST'] 返回瀏覽當(dāng)前頁面的用戶的主機名。
$_SERVER['REMOTE_PORT'] 返回用戶機器上連接到 Web 服務(wù)器所使用的端口號。
$_SERVER['SCRIPT_FILENAME'] 返回當(dāng)前執(zhí)行腳本的絕對路徑。
$_SERVER['SERVER_ADMIN'] 該值指明了 Apache 服務(wù)器配置文件中的 SERVER_ADMIN 參數(shù)。
$_SERVER['SERVER_PORT'] Web 服務(wù)器使用的端口。默認值為 “80”。
$_SERVER['SERVER_SIGNATURE'] 返回服務(wù)器版本和虛擬主機名。
$_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ù)。

下面的例子展示了一個包含輸入字段及提交按鈕的表單。當(dāng)用戶通過點擊提交按鈕來提交表單數(shù)據(jù)時, 表單數(shù)據(jù)將發(fā)送到 標(biāo)簽的 action 屬性中指定的腳本文件。在這個例子中,我們指定文件本身來處理表單數(shù)據(jù)。如果您需要使用其他的 PHP 文件來處理表單數(shù)據(jù),請修改為您選擇的文件名即可。然后,我們可以使用超級全局變量 $_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 表單后的表單數(shù)據(jù)。$_POST 也常用于傳遞變量。

下面的例子展示了一個包含輸入字段和提交按鈕的表單。當(dāng)用戶點擊提交按鈕來提交數(shù)據(jù)后,表單數(shù)據(jù)會發(fā)送到 標(biāo)簽的 action 屬性中指定的文件。在本例中,我們指定文件本身來處理表單數(shù)據(jù)。如果您希望使用另一個 PHP 頁面來處理表單數(shù)據(jù),請用更改為您選擇的文件名。然后,我們可以使用超全局變量 $_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") 之后的表單數(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)用戶點擊鏈接 "測試 $GET",參數(shù) "subject" 和 "web" 被發(fā)送到 "test_get.php",然后您就能夠通過 $_GET 在 "test_get.php" 中訪問這些值了。

下面的例子是 "test_get.php" 中的代碼:

實例

<html>
<body>

<?php 
echo "在 " . $_GET['web'] . " 學(xué)習(xí) " . $_GET['subject'];
?>

</body>
</html>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • php解析json數(shù)據(jù)實例

    php解析json數(shù)據(jù)實例

    這篇文章主要介紹了php解析json數(shù)據(jù)實例,很重要的一個應(yīng)用,需要的朋友可以參考下
    2014-08-08
  • php 時間time與日期date之間的使用詳解及區(qū)別

    php 時間time與日期date之間的使用詳解及區(qū)別

    PHP中有time函數(shù),也有date函數(shù),這兩個函數(shù)在使用時候的區(qū)別很明顯。但更應(yīng)注意,time和date是兩個完全不時的格式,當(dāng)然還有一種字符串格式。本文重點介紹這幾者的區(qū)別。
    2016-11-11
  • php生成圖片縮略圖功能示例

    php生成圖片縮略圖功能示例

    這篇文章主要介紹了php生成圖片縮略圖功能,結(jié)合完整實例形式分析了php縮略圖生成的詳細步驟與相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2017-02-02
  • php生成隨機顏色的方法

    php生成隨機顏色的方法

    這篇文章主要介紹了php生成隨機顏色的方法,通過一個自定義函數(shù)結(jié)合隨機數(shù)的生成來實現(xiàn)生成隨機顏色的功能,代碼簡潔易懂,是非常實用的技巧,需要的朋友可以參考下
    2014-11-11
  • php面向?qū)ο笾衧tatic靜態(tài)屬性與方法的內(nèi)存位置分析

    php面向?qū)ο笾衧tatic靜態(tài)屬性與方法的內(nèi)存位置分析

    這篇文章主要介紹了php面向?qū)ο笾衧tatic靜態(tài)屬性與方法的內(nèi)存位置,通過內(nèi)存位置實例分析了static靜態(tài)屬性的原理與使用技巧,需要的朋友可以參考下
    2015-02-02
  • PHP中使用break跳出多重循環(huán)代碼實例

    PHP中使用break跳出多重循環(huán)代碼實例

    這篇文章主要介紹了PHP中使用break跳出多重循環(huán)代碼實例,本文直接給出代碼,代碼簡潔易一懂,一看就明白了,需要的朋友可以參考下
    2015-01-01
  • php根據(jù)生日計算年齡的方法

    php根據(jù)生日計算年齡的方法

    這篇文章主要介紹了php根據(jù)生日計算年齡的方法,涉及php操作日期與字符串的相關(guān)技巧,非常簡單實用,需要的朋友可以參考下
    2015-07-07
  • 記錄PHP錯誤日志 display_errors與log_errors的區(qū)別

    記錄PHP錯誤日志 display_errors與log_errors的區(qū)別

    錯誤回顯,一般常用語開發(fā)模式,但是很多應(yīng)用在正式環(huán)境中也忘記了關(guān)閉此選項。錯誤回顯可以暴露出非常多的敏感信息,為攻擊者下一步攻擊提供便利。推薦關(guān)閉此選項
    2012-10-10
  • PHP+redis實現(xiàn)的限制搶購防止商品超發(fā)功能詳解

    PHP+redis實現(xiàn)的限制搶購防止商品超發(fā)功能詳解

    這篇文章主要介紹了PHP+redis實現(xiàn)的限制搶購防止商品超發(fā)功能,結(jié)合實例形式分析了PHP+redis通過數(shù)據(jù)標(biāo)記、日志記錄等操作防止商品搶購中的超發(fā)相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2019-09-09
  • php基于mcrypt的加密解密實例

    php基于mcrypt的加密解密實例

    這篇文章主要介紹了php基于mcrypt的加密解密的實現(xiàn)方法,以實例形式分析了mcrypt加密解密的原理與具體實現(xiàn)方法,非常具有實用價值,需要的朋友可以參考下
    2014-10-10

最新評論