站長資訊網
最全最豐富的資訊網站

詳解PHP中的9 個超全局變量(用法示例介紹)

詳解PHP中的9 個超全局變量(用法示例介紹)

超全局變量 在 PHP 4.1.0 中引入,是在全部作用域中始終可用的內置變量。PHP 中的許多預定義變量都是“超全局的”,這意味著它們在一個腳本的全部作用域中都可用。在函數或方法中無需執行 global $variable; 就可以訪問它們。

常用的超全局變量有9個:

1. $_GET –> get 傳送方式

2. $_POST –> post 傳送方式

3. $_REQUEST –> 可以接收到 get 和 post 兩種方式的值

4. $GLOBALS –> 引用全局作用域中可用的全部變量

5. $_FILES –> 上傳文件使用

6. $_SERVER –> 系統環境變量

7. $_SESSION –> 用于會話控制

8. $_COOKIE –> 用于會話控制

9. $_ENV –> 服務器端環境變量

下面給大家詳細介紹一下

1. $_GET –> get 傳送方式

PHP $_GET 也可用于收集提交 HTML 表單 (method=”get”) 之后的表單數據。
$_GET 也可以收集 URL 中的發送的數據。

例如訪問URL鏈接:

http://localhost/test_get.php?subject=PHP&web=W3school.com.cn

使用方式如下:

<html> <body>     <?php          echo "Study " . $_GET['subject'] . " at " . $_GET['web'];     ?> </body> </html>

2. $_POST –> post 傳送方式

PHP $_POST 廣泛用于收集提交 method=”post” 的 HTML 表單后的表單數據。$_POST 也常用于傳遞變量。

下面的例子展示了一個包含輸入字段和提交按鈕的表單。當用戶點擊提交按鈕來提交數據后,表單數據會發送到 <form> 標簽的 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>

3. $_REQUEST –> 可以接收到 get 和 post 兩種方式的值

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>

4. $GLOBALS –> 引用全局作用域中可用的全部變量

  • $GLOBALS 這種全局變量用于在 PHP 腳本中的任意位置訪問全局變量(從函數或方法中均可)。

  • PHP 在名為 $GLOBALS[index] 的數組中存儲了所有全局變量。變量的名字就是數組的鍵。

  • 主要用于在局部范圍不可以使用全局變量時,但又需要使用該全局變量,就使用$GLOBALS。

下面的例子展示了如何使用超級全局變量 $GLOBALS:

<?php      $x = 75;      $y = 25;      function addition() {        $GLOBALS['z'] = $GLOBALS['x'] + $GLOBALS['y'];      }      addition();      echo $z;  ?>

5. $_FILES –> 上傳文件使用

  • $_FILES 主要用在當需要上傳二進制文件的地方,錄入上傳一個abc.mp3文件,則服務器端需要獲得該文件的相關信息,則通過變量 $_FILES 來取得。

  • $_FILES 超級全局變量包含通過POST方法向服務器上傳的數據的有關信息。這個超級全局變量與其他的變量有所不同,它是一個二維數組,包含5個元素。

元素/代碼

描述

元素/代碼 描述

$_FILES[‘userfile’][‘name’]

客戶端機器文件的原名稱

$_FILES[‘userfile’][‘type’]

文件的 MIME 類型,需要瀏覽器提供該信息的支持,例如“image/gif”

$_FILES[‘userfile’][‘size’]

已上傳文件的大小,單位為字節

$_FILES[‘userfile’][‘tmp_name’]

文件被上傳后在服務端儲存的臨時文件名

$_FILES[‘userfile’][‘error’]

和該文件上傳相關的錯誤代碼。[‘error’] 是在 PHP 4.2.0 版本中增加的。盡管這個變量的名為 error ,但實際上在成功的情況下也會填寫這個變量。它有五個可能的值:見表格下方注釋③

注:
① 在 PHP 4.1.0 版本以前該數組的名稱為 $HTTP_POST_FILES,它并不像 $_FILES 一樣是自動全局變量。PHP 3 不支持 $HTTP_POST_FILES 數組。
② 如果表單中沒有選擇上傳的文件,則 PHP 變量 $_FILES[‘userfile’][‘size’] 的值將為 0,$_FILES[‘userfile’][‘tmp_name’] 將為 none。
③ error字段5個錯誤碼:

  • UPLOAD_ERR_OK 文件成功上傳

  • UPLOAD_ERR_INI_SIZE 文件大小超出了

  • MAX_FILE_SIZE 指令所指定的最大值。

  • UPLOAD_ERR_FORM_SIZE 文件大小超出了MAX_FILE_SIZE 隱藏表單域參數(可選)指定的最大值。

  • UPLOAD_ERR_PARTIAL 文件只上傳了一部分UPLOAD_ERR_NO_FILE 上傳表單中沒有指定文件

前端上傳文件示例代碼:

/**創建一個文件上傳表單 允許用戶從表單上傳文件是非常有用的。 請看下面這個供上傳文件的 HTML 表單:**/ <html> <body>     <form action="upload_file.php" method="post" enctype="multipart/form-data">         <label for="file">Filename:</label>         <input type="file" name="file" id="file" />          <input type="submit" name="submit" value="Submit" />     </form> </body> </html>

后端處理文件示例代碼:

<?php if ((($_FILES["file"]["type"] == "image/gif") || ($_FILES["file"]["type"] == "image/jpeg") || ($_FILES["file"]["type"] == "image/pjpeg")) && ($_FILES["file"]["size"] < 20000))   {   if ($_FILES["file"]["error"] > 0)     {     echo "Return Code: " . $_FILES["file"]["error"] . "<br />";     }   else     {     echo "Upload: " . $_FILES["file"]["name"] . "<br />";     echo "Type: " . $_FILES["file"]["type"] . "<br />";     echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />";     echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br />";      if (file_exists("upload/" . $_FILES["file"]["name"]))       {       echo $_FILES["file"]["name"] . " already exists. ";       }     else       {       move_uploaded_file($_FILES["file"]["tmp_name"],       "upload/" . $_FILES["file"]["name"]);       echo "Stored in: " . "upload/" . $_FILES["file"]["name"];       }     }   } else   {   echo "Invalid file";   } ?>

6. $_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[‘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。

7. $_SESSION –> 用于會話控制

PHP session 變量用于存儲有關用戶會話的信息,或更改用戶會話的設置。Session 變量保存的信息是單一用戶的,并且可供應用程序中的所有頁面使用。

  • 當您運行一個應用程序時,您會打開它,做些更改,然后關閉它。這很像一次會話。計算機清楚你是誰。它知道你何時啟動應用程序,并在何時終止。但是在因特網上,存在一個問題:服務器不知道你是誰以及你做什么,這是由于 HTTP 地址不能維持狀態。

  • 通過在服務器上存儲用戶信息以便隨后使用,PHP session 解決了這個問題(比如用戶名稱、購買商品等)。不過,會話信息是臨時的,在用戶離開網站后將被刪除。如果您需要永久儲存信息,可以把數據存儲在數據庫中。

  • Session 的工作機制是:為每個訪問者創建一個唯一的 id (UID),并基于這個 UID 來存儲變量。UID 存儲在 cookie 中,亦或通過 URL 進行傳導。

①開始 PHP Session :
在您把用戶信息存儲到 PHP session 中之前,首先必須啟動會話。
注釋:session_start() 函數必須位于 標簽之前

<?php session_start(); ?>  <html> <body>  </body> </html>

②存儲 和使用Session 變量:

<?php session_start(); // store session data $_SESSION['views']=1; ?>  <html> <body>  <?php //retrieve session data echo "Pageviews=". $_SESSION['views']; ?>  </body> </html>

③終結 Session
如果您希望刪除某些 session 數據,可以使用 unset() 或 session_destroy() 函數。

//通過 unset() 函數用于釋放指定的 session 變量: <?php unset($_SESSION['views']); ?>  //通過 session_destroy() 函數徹底終結 session: <?php session_destroy(); ?>

注釋:session_destroy() 將重置 session,您將失去所有已存儲的 session 數據。

8. $_COOKIE –> 用于會話控制

cookie 常用于識別用戶。cookie 是服務器留在用戶計算機中的小文件。每當相同的計算機通過瀏覽器請求頁面時,它同時會發送 cookie。通過 PHP,您能夠創建并取回 cookie 的值。

①創建 Cookie

//語法 setcookie(name, value, expire, path, domain);  //示例 <?php  setcookie("user", "Alex Porter", time()+3600); //創建名為 "user" 的 cookie,把為它賦值 "Alex Porter"。我們也規定了此 cookie 在一小時后過期 ?>  <html> <body>  </body> </html>

②取回 Cookie 值

//示例a:取回了名為 "user" 的 cookie 的值,并把它顯示在了頁面上 <?php // Print a cookie echo $_COOKIE["user"];  // A way to view all cookies print_r($_COOKIE); ?>  //示例b:使用 isset() 函數來確認是否已設置了 cookie <html> <body>  <?php if (isset($_COOKIE["user"]))   echo "Welcome " . $_COOKIE["user"] . "!<br />"; else   echo "Welcome guest!<br />"; ?>  </body> </html>

9. $_ENV –> 服務器端環境變量

PHP中的$_ENV是一個包含服務器端環境變量的數組,不同系統不完全一樣。
部分變量示例:
$_ENV[ ‘HOSTNAME’ ] 服務器的主機名
$_ENV[ ‘SHELL’ ] 系統 shell

$_ENV只是被動的接受服務器端的環境變量并把它們轉換為數組元素,你可以嘗試直接輸出它:

//輸出內容格式清晰,ThinkPHP可以直接用dump() var_dump($_ENV);  //輸出到屏幕 print_r($_ENV);  //輸出key-value鍵值對 foreach($_ENV as $key=>$val){echo $key.'--------'.$val.'<br>';}

【相關教程推薦:《PHP教程》】

贊(0)
分享到: 更多 (0)
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
国产欧美一区二区精品仙草咪| 免费在线观看日韩| 青青草国产精品久久久久| 国产精品日本亚洲777| 久久99精品福利久久久| 无码国模国产在线无码精品国产自在久国产 | 国产成人精品免费视频大全五级 | 亚洲国产日产无码精品| 精品国精品国产自在久国产应用男 | 国产高清在线精品一区| 国内精品久久人妻互换| 国产日韩精品一区二区三区| 精品国产一区二区三区| 久久精品午夜一区二区福利| 国产精品自产拍高潮在线观看| 国产精品国产三级国产普通话a| 国产99久久精品一区二区| 国产精品污WWW在线观看| 七月婷婷精品视频在线观看| 国产精品久久久久网站| 久久久午夜精品福利内容| 无码国产精品一区二区免费模式 | 日韩精品电影一区亚洲| 国产精品线在线精品国语| 亚洲AV无码乱码麻豆精品国产| 久久精品成人免费网站| 国产精品热久久无码av| 日韩丰满少妇无吗视频激情内射| 国产精品毛片大码女人| 国产第一福利精品导航| 亚洲国产精品久久久久婷婷软件 | 久久免费国产精品一区二区| japanese乱人伦精品| 亚洲AV日韩AV高潮无码专区| 日本精品在线观看视频| av国内精品久久久久影院| 精品视频一区二区三三区四区| 国产成人精品一区二区三区免费| 久久久久亚洲精品中文字幕| 日韩一品在线播放视频一品免费| 国产成人精品高清免费|