溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

PHP預(yù)定義常量和超全局變量的方法是什么

發(fā)布時(shí)間:2023-03-21 15:33:50 來源:億速云 閱讀:79 作者:iii 欄目:編程語言

今天小編給大家分享一下PHP預(yù)定義常量和超全局變量的方法是什么的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

預(yù)定義常量

預(yù)定義常量在PHP中擁有一個(gè)特殊的定義:在PHP腳本開始運(yùn)行之前就已經(jīng)被定義。常用的預(yù)定義常量包括:

  • LINE :代表的是代碼行數(shù)。

  • FILE :代表的是文件的路徑和名稱。

  • DIR :代表的是文件所在目錄的絕對(duì)路徑。

  • FUNCTION :代表的是函數(shù)名稱。

  • CLASS :代表的是類名,包括命名空間。

  • TRAIT :代表的是 trait 名字,包括命名空間。

  • METHOD :代表的是類的方法名稱。

  • NAMESPACE :代表的是當(dāng)前命名空間名稱。

這些預(yù)定義常量是可讀的,但不可重新賦值,例如:

<?php
echo __FILE__; // 輸出當(dāng)前文件的路徑
echo __LINE__; // 輸出當(dāng)前代碼的行數(shù)
?>

預(yù)定義常量的用途是幫助開發(fā)人員快速定位和調(diào)試代碼,可能會(huì)用在錯(cuò)誤報(bào)告中,或者記錄代碼執(zhí)行路徑和時(shí)間戳等。

超全局變量

超全局變量則是在PHP腳本任何地方都可以訪問的變量,不用擔(dān)心作用域或者函數(shù)的參數(shù)傳遞。所有的超全局變量都是以一個(gè)下劃線開始的全局變量數(shù)組,并且在不同的版本中數(shù)組名不同。 超全局變量有以下幾種類型:

  • $GLOBALS: 包含全部變量的全局作用域數(shù)組,變量的名稱就是數(shù)組的鍵。

  • $_SERVER: 服務(wù)器和執(zhí)行環(huán)境的信息。比如:$_SERVER['PHP_SELF'] 返回當(dāng)前執(zhí)行腳本的文件名。

  • $_GET: HTTP GET 變量。

  • $_POST: HTTP POST 變量。

  • $_FILES: HTTP 文件上傳變量。

  • $_REQUEST: HTTP Request 變量,它同時(shí)包含了 $_GET,$_POST 和 $_COOKIE 變量的內(nèi)容。

  • $_SESSION: Session 變量。

  • $_COOKIE: HTTP Cookies。

  • $_ENV: 環(huán)境變量。

$_SERVER超全局變量的示例:

<?php
echo $_SERVER['PHP_SELF']; //顯示當(dāng)前執(zhí)行腳本的文件名,即 index.php
echo $_SERVER['SERVER_NAME']; // 顯示當(dāng)前運(yùn)行腳本所在的服務(wù)器的主機(jī)名(本機(jī) IP)
echo $_SERVER['HTTP_REFERER']; // 獲取網(wǎng)頁的來源地址 (referer)
echo $_SERVER['DOCUMENT_ROOT']; // 顯示當(dāng)前執(zhí)行腳本的文檔根目錄(/var/www/)
?>

超全局變量的好處是在需要訪問全局變量的時(shí)候,不需要在每個(gè)函數(shù)中都傳遞這些變量。但是,因?yàn)槿魏文_本的任何地方都可以直接訪問這些變量,所以也帶來了一些安全問題,攻擊者可以利用一些漏洞修改這些全局變量的內(nèi)容,導(dǎo)致系統(tǒng)產(chǎn)生異常,而調(diào)試分析異常的原因也會(huì)更加困難。

以上就是“PHP預(yù)定義常量和超全局變量的方法是什么”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI