本篇文章為大家帶來了關於PHP的相關知識,其中主要介紹了關於超級全域變數的相關內容,超級全域變數是一種特殊的變數類型,是內建的和預先定義的,可以從任何範圍內訪問,不需要執行任何特殊的程式碼片段,下面一起來看一下,希望對大家有幫助。
理解PHP超級全域
超級全域變數是一種特殊的變數類型,因為它們可以從任何範圍內存取。可以從任何文件、類別、甚至函數中訪問,而不需要執行任何特殊的程式碼段。
超全域變數是內建的和預先定義的。程式設計師可以透過PHP類別庫來使用它們。請注意,在類別庫中並非所有內建的預定義變數都是超全域變數。
前提條件
要理解本文的內容,讀者應該具備以下條件。
- 對 PHP 變數宣告技術有基本了解。
- 對 PHP 有初步的了解。
PHP超級全域變數簡介
超級全域變數是在 PHP 4.1.0 中引入的,此後一直是 PHP 的一個重要組成部分。在PHP中大約有9個超全域變量,有時被稱為automatic globals
。它們如下所述。
$GLOBALS
$_SERVER
$_GET
$_POST
$_REQUEST
#$_SESSION
- ##$_COOKIE
- $_FILE
- $_ENV
$GLOBALS
variable name` 。 下面是一個使用超全域變數$GLOBAL
的範例:)<pre class="brush:php;toolbar:false"> nbsp;html>
<title>GLOBAL example</title>
<?php //php Script
// Varriable declaration
$a = 5;
$b = 6;
function multiplication(){
$GLOBALS[&#39;c&#39;] = $GLOBALS[&#39;a&#39;]* $GLOBALS[&#39;b&#39;];
}
multiplication();
echo $c;
?>
</pre>
在上面的範例中,變數
在函數內部和外部都可以訪問,因為它在$GLOBALS
陣列中。
$_SERVER
是一個超全域變量,用於保存PHP腳本的資訊頭、路徑和位置。變數有幾個元素被保存。它們包括$_SERVER
$_SERVER['PHP_SELF'] - 它傳回目前正在執行的腳本的檔案名稱。
- $_SERVER['SERVER_NAME'] - 這傳回託管網站的伺服器的名稱。
- $_SERVER['HTTP_HOST'] - 這將傳回目前要求的主機頭。
- $_SERVER['SCRIPT_NAME'] - 這傳回目前腳本的路徑。
- 下面是一個顯示如何使用上述元素的範例程式碼。
-
nbsp;html> <title> $_SERVER example</title> <?php // PHP script echo $_SERVER['PHP_SELF']; echo "<br>"; echo $_SERVER['SERVER_NAME']; echo "<br>"; echo $_SERVER['HTTP_HOST']; echo "<br>"; echo $_SERVER['SCRIPT_NAME']; ?>
上述程式碼的輸出將包括。
- 一个文件名。
- 主机服务器的名称。
- 主机当前请求的标题。
- 当前脚本的路径。
$_GET
$_GET
变量是一个PHP超全局变量,用于收集HTML表单提交后的数据。HTML表单的结构是这样的:$_GET
作为一个方法。$_GET
也可以用来检索在uniform resource locator
中发送的数据。下面是一个例子,说明如何在HTML表单中实现
$_GET
变量。nbsp;html> <title>$_GET example</title> <!-- html form -->
当用户点击
Submit
按钮时,表单中的信息会用GET
方法发送,并显示在URL
。然而,每次最多只能发送2048
字符。$_POST
就像
$_GET
变量一样,$_POST
收集来自HTML表单的值。使用这种方法发送的信息不会显示在URL中。一次可以发送的字符数也没有限制。下面是一个例子。
nbsp;html> <title>$_POST example</title> <!-- html form -->
为什么POST变量优于GET?
尽管
POST
和GET
方法实现了相同的功能,但由于以下原因,POST
更受青睐。POST方法对可以发送的数据大小没有限制。
POST方法可以同时发送ASCII和二进制数据。
POST方法不会在URL上显示正在发送的信息,因此可以防止建立书签。
POST方法使用一个
HTTP header
来发送数据。这促进了数据安全。
$_REQUEST
$_REQUEST
变量是一个PHP超全局,用于在提交表单后收集数据。它包含了$_GET
,$_POST
,甚至默认的$_COOKIE
的内容。各个字段的数据可以由PHP使用$_REQUEST
变量来收集。下面的例子显示了如何使用
$_REQUEST
这个变量。nbsp;html> <title>$_REQUEST example</title>
上述代码的输出将是表单中已提交的
name
。如果没有提交名字,它将打印一个信息Empty name
。$_SESSION
$_SESSION
变量是一个PHP的超级全局,它可以在用户每次打开网站时存储和利用有关网站用户的信息,直到网站关闭。每次用户访问网站时,都会启动一个会话。下面的函数被用来在PHP代码中启动一个会话。
session_start()
会话开始后,需要使用
$_SESSION
变量进行设置。当用户离开一个网站时,会话被自动销毁。这是在用户不知情的情况下使用下面的PHP函数完成的。
session_destroy()
下面的例子演示了
$_SESSION
的使用。php session_start(); ?> nbsp;html> <title>$_SESSION demonstration code</title> <?php //Set session varriables $_SESSION["name"]="Mackrine"; $_SESSION["favcolor"]="Blue"; echo "session varriables are set"; ?>
$_COOKIE
Cookie是一个小文件,由服务器存储在用户的计算机中。它可以识别用户。每当向服务器发出请求时。通常会在请求的同时发送一个cookie。PHP 使用
setcookie()
函数创建 cookie。setcookie(cookie_name,cookie_value, expiry, path, domain,secure,httponly)
该语法有许多参数。然而,只有
name
参数是必需的。在创建之后,可以使用超全局
$_COOKIE
变量来检索cookie。下面的代码显示了如何创建和检索一个cookie。<?php $cookie_name = "uname"; $cookie_value = "Mackrine"; //setting cookie setcookie($cookie_name, $cookie_value, time()+(86400*30),"/"); ?> nbsp;html> <?php if(isset($_COOKIE[$cookie_name])) { echo "Cookie name:" .$cookie_name; echo "<br>"; echo "Cookie value:" .$cookie_value; } else { echo $cookie_name. " is not set!"; } ?>
只有在过期的情况下,才可以使用
setcookie()
函数删除cookie。$_FILES
$_FILES
是一个变量,包含使用HTTPPOST方法上传的项目。 数组包含几个元素,如下所述。$_FILES
$_FILES['file']['name'] - 这通常是要上传的文件的原始名称。
$_FILES['file']['type'] - 这是指被上传文件的类型。
$_FILES['file']['size'] - 以字节为单位的文件大小。
$_FILES['file']['tmp_name'] - 它指的是在服务器上上传的存储文件的临时文件名。
$_FILE['file']['error']- 文件上传的相关错误代码。
总结
超全局变量是PHP语言的核心。在PHP编程中需要这些变量来制作高功能的程序。因此,你可以利用这些信息来制作高质量的应用程序。
推荐学习:《PHP视频教程》
以上是簡單理解PHP超級全域變數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

PHP用於構建動態網站,其核心功能包括:1.生成動態內容,通過與數據庫對接實時生成網頁;2.處理用戶交互和表單提交,驗證輸入並響應操作;3.管理會話和用戶認證,提供個性化體驗;4.優化性能和遵循最佳實踐,提升網站效率和安全性。

PHP在數據庫操作和服務器端邏輯處理中使用MySQLi和PDO擴展進行數據庫交互,並通過會話管理等功能處理服務器端邏輯。 1)使用MySQLi或PDO連接數據庫,執行SQL查詢。 2)通過會話管理等功能處理HTTP請求和用戶狀態。 3)使用事務確保數據庫操作的原子性。 4)防止SQL注入,使用異常處理和關閉連接來調試。 5)通過索引和緩存優化性能,編寫可讀性高的代碼並進行錯誤處理。

在PHP中使用預處理語句和PDO可以有效防範SQL注入攻擊。 1)使用PDO連接數據庫並設置錯誤模式。 2)通過prepare方法創建預處理語句,使用佔位符和execute方法傳遞數據。 3)處理查詢結果並確保代碼的安全性和性能。

PHP和Python各有優劣,選擇取決於項目需求和個人偏好。 1.PHP適合快速開發和維護大型Web應用。 2.Python在數據科學和機器學習領域佔據主導地位。

PHP在電子商務、內容管理系統和API開發中廣泛應用。 1)電子商務:用於購物車功能和支付處理。 2)內容管理系統:用於動態內容生成和用戶管理。 3)API開發:用於RESTfulAPI開發和API安全性。通過性能優化和最佳實踐,PHP應用的效率和可維護性得以提升。

PHP可以輕鬆創建互動網頁內容。 1)通過嵌入HTML動態生成內容,根據用戶輸入或數據庫數據實時展示。 2)處理表單提交並生成動態輸出,確保使用htmlspecialchars防XSS。 3)結合MySQL創建用戶註冊系統,使用password_hash和預處理語句增強安全性。掌握這些技巧將提升Web開發效率。

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

PHP仍然具有活力,其在現代編程領域中依然佔據重要地位。 1)PHP的簡單易學和強大社區支持使其在Web開發中廣泛應用;2)其靈活性和穩定性使其在處理Web表單、數據庫操作和文件處理等方面表現出色;3)PHP不斷進化和優化,適用於初學者和經驗豐富的開發者。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

禪工作室 13.0.1
強大的PHP整合開發環境

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。